:root{--color-white: #ffffff;--color-black: #000000;--color-text: #333333;--gray-light: #f5f5f5;--gray-medium: #e0e0e0;--gray-dark: #666666;--gray-blue: #f8f9fc;--blue-light: #e3f2fd;--blue-primary: #005bbb;--blue-dark: #1565c0;--toast-success: #4caf50;--toast-error: #f44336;--toast-warning: #ff9800;--toast-info: #2196f3;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .05);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 4px 12px rgba(0, 0, 0, .15);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .2);--header-height: 56px;--sidebar-width: 220px;--overlay-light: rgba(0, 0, 0, .35);--overlay: rgba(0, 0, 0, .5)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Google Sans,Roboto,RobotoDraft,Helvetica,Arial,sans-serif;font-size:.875rem;color:var(--color-text);background:var(--gray-light);-webkit-font-smoothing:antialiased}.material-symbols-outlined{font-variation-settings:"FILL" 0,"wght" 400,"GRAD" 0,"opsz" 20}.g-btn,.g-btn-ghost,.g-btn-primary{background-color:var(--gray-medium);border:none;padding:.6rem 1.2rem;border-radius:6px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:6px;font-size:.85rem;color:var(--color-text);transition:background .15s,box-shadow .2s ease}.g-btn:hover,.g-btn-ghost:hover,.g-btn-primary:hover{box-shadow:var(--shadow-sm)}.g-btn .material-symbols-outlined,.g-btn-ghost .material-symbols-outlined,.g-btn-primary .material-symbols-outlined{font-size:18px}.g-btn-primary{background-color:var(--blue-primary);color:var(--color-white)}.g-btn-primary:hover{background-color:var(--blue-dark)}.g-btn-ghost{background:transparent}.g-btn-ghost:hover{background:var(--gray-light)}.g-btn-icon,.g-btn-icon-sm{width:36px;height:36px;border:none;border-radius:6px;background:var(--gray-medium);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;color:var(--color-text);transition:background .15s,box-shadow .2s}.g-btn-icon:hover,.g-btn-icon-sm:hover{background:var(--gray-dark);color:var(--color-white);box-shadow:var(--shadow-sm)}.g-btn-icon .material-symbols-outlined,.g-btn-icon-sm .material-symbols-outlined{font-size:18px}.g-btn-icon-sm{width:28px;height:28px}.g-btn-icon-sm .material-symbols-outlined{font-size:16px}.g-btn-tab{background:none;border:none;cursor:pointer;padding:.5rem 1rem;font-size:.95rem;color:var(--gray-dark);transition:all .15s;position:relative;border-radius:6px}.g-btn-tab:hover{background:var(--gray-light);color:var(--color-text)}.g-btn-tab.active{color:var(--blue-primary);font-weight:600}.g-btn-subtab{padding:.5rem 1rem;padding-bottom:6px;background:none;border:none;border-bottom:2px solid transparent;font-size:.9rem;font-weight:700;color:var(--gray-dark);cursor:pointer;transition:border-color .15s ease}.g-btn-subtab:hover{border-bottom-color:var(--gray-dark)}.g-btn-subtab.active{color:var(--blue-primary);border-bottom-color:var(--blue-primary)}table{width:100%;border-collapse:collapse;font-size:.85rem;background:var(--color-white);border:1px solid var(--gray-medium);border-radius:6px;overflow:hidden}table thead{background-color:var(--gray-blue)}table thead th{font-weight:600;text-align:center;padding:8px 16px;height:32px;color:var(--color-text);border-bottom:1px solid var(--gray-medium);border-right:1px solid var(--gray-medium)}table thead th:last-child{border-right:none}table tbody td{padding:0 16px;height:36px;vertical-align:middle;border-bottom:1px solid var(--gray-light);border-right:1px solid var(--gray-light)}table tbody td:last-child{border-right:none}table tbody tr:hover{background:var(--gray-light)}input,select,textarea{font-family:inherit;font-size:.85rem}.g-input{width:100%;padding:.5rem .75rem;border:1px solid var(--gray-medium);border-radius:6px;font-size:.85rem;background:var(--color-white);outline:none}.g-input:focus{border-color:var(--blue-primary)}.g-input:disabled{background:var(--gray-light);color:var(--gray-dark)}.g-modal-overlay{position:fixed;inset:0;background:var(--overlay-light);display:flex;justify-content:center;align-items:center;z-index:9999}.g-modal-container{background:var(--color-white);border-radius:1rem;box-shadow:var(--shadow-lg);max-width:95vw;max-height:85vh;display:flex;flex-direction:column;width:1440px}.g-modal-header{display:flex;justify-content:space-between;align-items:center;padding:.8rem 1rem;background:var(--gray-light);border-bottom:1px solid var(--gray-medium);border-radius:1rem 1rem 0 0}.g-modal-header h2{font-size:1rem;font-weight:500;margin:0}.g-modal-body{padding:1rem;overflow-y:auto;flex:1}.g-modal-footer{display:flex;justify-content:center;gap:.9rem;padding:.8rem 1rem;border-top:1px solid var(--gray-medium)}.text-center{text-align:center}.text-right{text-align:right}.mono{font-family:Consolas,Monaco,Courier New,monospace;font-size:.8rem}.checkbox-icon{cursor:pointer;font-size:20px;color:var(--gray-dark);-webkit-user-select:none;user-select:none;vertical-align:middle}.checkbox-icon.checked{color:var(--blue-primary)}.checkbox-icon.disabled{cursor:default;opacity:.5}.badge{display:inline-block;padding:.15rem .5rem;border-radius:.5rem;font-size:.75rem;font-weight:500}.badge.active{background:#d1fae5;color:#065f46}.badge.inactive{background:var(--gray-light);color:var(--gray-dark)}.badge.info{background:#dbeafe;color:#1e40af}.badge.warn{background:#fef3c7;color:#92400e}.badge.danger{background:#fee2e2;color:#991b1b}.auth-background{position:fixed;inset:0;background:radial-gradient(ellipse at center,#1a1a2e,#0a0a14);z-index:-1}.auth-container{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);max-width:420px;padding:3rem 2.5rem;border-radius:20px;box-shadow:var(--shadow-md),var(--shadow-xs)}@keyframes g-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spinning{animation:g-spin 1s linear infinite}
