*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Microsoft YaHei,sans-serif;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;color:#333}.container{max-width:720px;margin:0 auto;padding:40px 20px}.card{background:#fff;border-radius:16px;padding:32px;box-shadow:0 10px 40px #00000026}h1{text-align:center;margin-bottom:8px;color:#4a4a8a}.subtitle{text-align:center;color:#888;margin-bottom:28px}.tabs{display:flex;gap:12px;margin-bottom:24px;justify-content:center}.tab{padding:10px 24px;border-radius:8px;border:1px solid #ddd;background:#f8f9fa;cursor:pointer;font-size:15px;transition:all .2s}.tab.active{background:#667eea;color:#fff;border-color:#667eea}.input-group{margin-bottom:18px}label{display:block;margin-bottom:6px;font-size:14px;color:#555;font-weight:500}input[type=text],input[type=number],textarea{width:100%;padding:12px 14px;border:1px solid #ddd;border-radius:8px;font-size:15px;outline:none;transition:border .2s}input:focus,textarea:focus{border-color:#667eea}textarea{min-height:140px;resize:vertical;font-family:inherit;line-height:1.6}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:12px 24px;border:none;border-radius:8px;font-size:15px;cursor:pointer;transition:all .2s}.btn-primary{background:#667eea;color:#fff}.btn-primary:hover{background:#5a6fd6}.btn-block{width:100%}.btn-danger{background:#ff6b6b;color:#fff}.btn-danger:hover{background:#e55c5c}.btn-sm{padding:6px 12px;font-size:13px}.message{margin-top:18px;padding:14px;border-radius:8px;font-size:14px}.message.success{background:#e6f9ed;color:#2b8a3e;border:1px solid #b2f2bb}.message.error{background:#fff0f0;color:#c92a2a;border:1px solid #ffc9c9}.result-box{margin-top:20px;padding:18px;background:#f8f9fa;border-radius:10px;border:1px dashed #667eea}.result-box h3{font-size:14px;color:#666;margin-bottom:8px}.card-key{font-family:SFMono-Regular,Consolas,monospace;font-size:16px;word-break:break-all;color:#333;background:#fff;padding:12px;border-radius:6px;border:1px solid #e0e0e0;margin-bottom:12px}.code-list{margin-top:20px}.code-list table{width:100%;border-collapse:collapse;font-size:14px}.code-list th,.code-list td{padding:10px;text-align:left;border-bottom:1px solid #eee}.code-list th{color:#666;font-weight:600;background:#f8f9fa}.short-code{font-family:SFMono-Regular,Consolas,monospace;font-weight:600;color:#667eea}.empty{text-align:center;color:#999;padding:20px 0}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:100;padding:20px}.modal{background:#fff;border-radius:12px;width:100%;max-width:520px;max-height:80vh;overflow:hidden;box-shadow:0 20px 60px #00000040}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #eee}.modal-header h3{font-size:18px;color:#333}.modal-close{background:none;border:none;font-size:24px;color:#999;cursor:pointer;line-height:1}.modal-close:hover{color:#333}.modal-body{padding:20px;overflow-y:auto;max-height:calc(80vh - 60px)}.modal-body p{margin-bottom:8px;font-size:14px;color:#555}.records-table{width:100%;border-collapse:collapse;font-size:14px;margin-top:8px}.records-table th,.records-table td{padding:10px;text-align:left;border-bottom:1px solid #eee}.records-table th{background:#f8f9fa;color:#666;font-weight:600}.admin-auth{display:flex;gap:12px;margin-bottom:20px}.admin-auth input{flex:1}.hint{font-size:12px;color:#999;margin-top:4px}.checkbox-label{display:flex;align-items:center;gap:8px;font-weight:400;cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:#667eea;cursor:pointer}select{width:100%;padding:12px 14px;border:1px solid #ddd;border-radius:8px;font-size:15px;outline:none;background:#fff;cursor:pointer}select:focus{border-color:#667eea}select:disabled{background:#f0f0f0;color:#999;cursor:not-allowed}.code-list-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:28px;margin-bottom:12px}.code-list-header h3{font-size:18px;color:#333}.group-filter{width:auto;min-width:160px;padding:8px 12px;font-size:14px}.group-section{margin-top:8px}.group-create{display:flex;gap:12px;align-items:flex-end;margin-bottom:20px}.group-list{display:flex;flex-direction:column;gap:12px}.group-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;background:#f8f9fa;border-radius:10px;border:1px solid #eee}.group-info{flex:1;min-width:0}.group-name{font-size:15px;font-weight:600;color:#333;margin-bottom:4px}.group-meta{font-size:12px;color:#888}.group-actions{display:flex;gap:8px;flex-shrink:0}@media (max-width: 560px){.group-create{flex-direction:column;align-items:stretch}.group-create .btn{width:100%}.group-item{flex-direction:column;align-items:flex-start}.group-actions{width:100%}.group-actions .btn{flex:1}.code-list-header{flex-direction:column;align-items:flex-start}.group-filter{width:100%}}
