:root{font-family:Arial,sans-serif}body{margin:0;background:#f7fbff;color:#0f172a}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#e3f2fd,#81d4fa);padding:20px}.login-container{background:#fffffff2;padding:40px;border-radius:20px;box-shadow:0 15px 35px #0000001a;width:100%;max-width:420px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2)}.login-header{text-align:center;margin-bottom:24px}.system-title{margin:0 0 6px;font-size:24px;font-weight:600;color:#1677ff}.system-subtitle{margin:0;font-size:18px;font-weight:500;color:#1f2f4a}.login-form{display:flex;flex-direction:column;gap:12px}.login-form-classic label{font-size:13px;color:#334155;font-weight:600}.login-form-classic input{background:#f8fafc;border:1px solid #cbd5e1}.login-btn{width:100%}.login-help{text-align:center;color:#6b7a99;font-size:12px;margin:6px 0 0}.layout{min-height:100vh;display:flex}.layout-aside{width:220px;background:#f0f6ff;border-right:1px solid #e0edff}.logo{height:60px;display:flex;align-items:center;justify-content:center;font-weight:600;color:#1677ff}.menu{display:flex;flex-direction:column;padding:8px;gap:6px}.menu-item{text-align:left;background:transparent;color:#334155;border:1px solid transparent}.menu-item:hover{background:#eaf4ff;border-color:#bfdbfe}.menu-item.active{background:#dbeafe;border-color:#93c5fd;color:#0c4a6e;font-weight:600}.layout-main{flex:1}.layout-header{height:60px;background:#fff;border-bottom:1px solid #e0edff;display:flex;align-items:center;justify-content:space-between;padding:0 16px}.title{font-size:16px;font-weight:500;color:#303133}.actions{display:flex;align-items:center;gap:8px}.container{padding:16px}.card{background:#fff;border-radius:8px;padding:12px;margin-bottom:12px}.row{display:flex;gap:8px;flex-wrap:wrap}input,select,button,textarea{padding:8px;border:1px solid #cbd5e1;border-radius:6px}button{background:#0284c7;color:#fff;border:0;cursor:pointer}.list-item{border-bottom:1px solid #e2e8f0;padding:8px 0}.small{color:#64748b;font-size:12px}.btn-light{margin-left:8px;background:#dbeafe;color:#0c4a6e;border:1px solid #7dd3fc}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:8px;margin-bottom:8px}.stats-card{background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;padding:8px;font-weight:600}.modal-mask{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a5c;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-card{width:420px;max-width:calc(100vw - 24px);background:#fff;border-radius:10px;border:1px solid #dbeafe;padding:14px}.modal-card h3{margin:0 0 12px;color:#0f172a}.modal-form{flex-direction:column}.modal-form input{width:100%;box-sizing:border-box}.modal-actions{justify-content:flex-end;margin-top:8px}.catalog-group{margin-bottom:16px}.catalog-group h5{margin:8px 0;color:#0f172a}.catalog-row{display:flex;align-items:center;gap:12px;margin-top:6px;flex-wrap:wrap}.order-page .msg{border-radius:8px;padding:10px 12px;margin-bottom:10px;font-size:13px}.order-page .msg-success{background:#ecfdf3;border:1px solid #bbf7d0;color:#166534}.order-page .msg-error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.order-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px;margin-bottom:10px}.order-grid .field{display:flex;flex-direction:column;gap:6px}.order-grid .field label{font-size:12px;color:#334155}.table-wrap{overflow-x:auto}.order-table{width:100%;border-collapse:collapse}.order-table th,.order-table td{border-bottom:1px solid #e2e8f0;padding:8px;text-align:left;white-space:nowrap;font-size:13px}.order-table thead th{background:#f8fafc;color:#475569;font-weight:600}.btn-danger-light{border-color:#fda4af;background:#ffe4e6;color:#9f1239}.btn-danger{background:#dc2626}.order-confirm-card{width:460px}.product-page .msg{border-radius:8px;padding:10px 12px;margin-bottom:10px;font-size:13px}.product-page .msg-success{background:#ecfdf3;border:1px solid #bbf7d0;color:#166534}.product-page .msg-error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.product-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px;margin-bottom:10px}.product-grid .field{display:flex;flex-direction:column;gap:6px}.product-grid .field label{font-size:12px;color:#334155}.product-grid .field-full{grid-column:1 / -1}.product-grid textarea{min-height:88px;resize:vertical}.course-list{margin-top:10px}.course-block{border:1px solid #dbeafe;border-radius:10px;margin-bottom:10px;overflow:hidden}.course-head{background:#f8fbff;display:flex;justify-content:space-between;align-items:center;gap:8px;padding:10px;cursor:pointer}.course-title-wrap{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.status-tag{border-radius:999px;padding:2px 8px;font-size:12px}.status-tag.ok{background:#dcfce7;color:#166534}.status-tag.off{background:#e2e8f0;color:#475569}.material-table-wrap{padding:8px 10px 12px}.material-table{width:100%;border-collapse:collapse}.material-table th,.material-table td{border-bottom:1px solid #e2e8f0;padding:8px;text-align:left;font-size:13px}.material-table thead th{background:#f8fafc;color:#475569;font-weight:600}.user-page .msg{border-radius:8px;padding:10px 12px;margin-bottom:10px;font-size:13px}.user-page .msg-success{background:#ecfdf3;border:1px solid #bbf7d0;color:#166534}.user-page .msg-error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.user-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px;margin-bottom:10px}.user-grid .field{display:flex;flex-direction:column;gap:6px}.user-grid .field label{font-size:12px;color:#334155}.user-grid .field-full{grid-column:1 / -1}.user-grid textarea{min-height:88px;resize:vertical}.user-table{width:100%;border-collapse:collapse}.user-table th,.user-table td{border-bottom:1px solid #e2e8f0;padding:8px;text-align:left;white-space:nowrap;font-size:13px}.user-table thead th{background:#f8fafc;color:#475569;font-weight:600}
