:root{--theme-primary: #20a50a;--theme-primary-soft: rgba(32, 165, 10, .18);--theme-primary-hover: #1b9009;font-family:Segoe UI,PingFang SC,Microsoft YaHei,sans-serif;color:#1f2937;background:#eef2ff;line-height:1.5;font-weight:400}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:radial-gradient(circle at top left,var(--theme-primary-soft),transparent 28%),linear-gradient(180deg,#f8fbff,#eef2ff)}button,input{font:inherit}button{border:none;border-radius:10px;padding:10px 16px;cursor:pointer;background:var(--theme-primary);color:#fff;transition:opacity .2s ease,transform .2s ease}button:hover{opacity:.92;transform:translateY(-1px)}button:disabled{opacity:.65;cursor:not-allowed;transform:none}input{width:100%;padding:10px 12px;border:1px solid #cbd5e1;border-radius:10px;background:#fff}#root{min-height:100vh}.auth-layout{min-height:100vh;display:grid;place-items:center;padding:24px}.auth-card,.panel{background:#ffffffe0;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(148,163,184,.2);border-radius:20px;box-shadow:0 24px 50px #0f172a14}.auth-card{width:min(420px,100%);padding:32px}.auth-card h1,.page-header h1,.panel h2{margin:0 0 8px}.login-form,.module-form{display:grid;gap:16px;margin-top:24px}.form-row{display:grid;gap:8px}.checkbox-row{display:flex;gap:10px;align-items:center}.checkbox-row input{width:auto}.form-actions,.table-actions,.panel-header,.page-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.page-layout{max-width:1200px;margin:0 auto;padding:40px 20px 60px;display:grid;gap:24px}.panel{padding:24px}.secondary-button{background:#e2e8f0;color:#0f172a}.danger-button{background:#dc2626}.module-table{width:100%;border-collapse:collapse}.module-table th,.module-table td{padding:14px 12px;border-bottom:1px solid #e2e8f0;text-align:left;vertical-align:middle}.status{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;font-size:14px}.status.active{color:#166534;background:#dcfce7}.status.inactive{color:#9a3412;background:#ffedd5}.error-banner,.loading-state,.empty-state{margin-top:16px;padding:12px 14px;border-radius:12px}.error-banner{color:#991b1b;background:#fee2e2}.loading-state,.empty-state{color:#334155;background:#f8fafc}.table-wrapper{overflow-x:auto}.switch{display:inline-flex;align-items:center;gap:10px;cursor:pointer;-webkit-user-select:none;user-select:none}.switch input{position:absolute;opacity:0;pointer-events:none;width:0;height:0}.switch-slider{position:relative;width:46px;height:26px;border-radius:999px;background:#cbd5e1;transition:background-color .2s ease}.switch-slider:after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 2px 6px #0f172a33;transition:transform .2s ease}.switch input:checked+.switch-slider{background:var(--theme-primary)}.switch input:checked+.switch-slider:after{transform:translate(20px)}.switch-label{min-width:56px;font-size:14px;color:#334155}.switch-loading{cursor:not-allowed;opacity:.72}@media(max-width:768px){.page-header,.panel-header,.form-actions,.table-actions{flex-direction:column;align-items:stretch}.module-table{min-width:760px}}
