*{box-sizing:border-box}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh;background-color:#fffdf9}#root{min-height:100vh}a{color:#667eea;text-decoration:none}a:hover{text-decoration:underline}button{border-radius:6px;border:1px solid transparent;padding:.5em 1em;font-size:1em;font-weight:500;font-family:inherit;background-color:#fffbf5;color:#fff;cursor:pointer;transition:background-color .2s,transform .1s}button:hover{background-color:#fffbf5}button:active{transform:scale(.98)}button:focus-visible{outline:2px solid #667eea;outline-offset:2px}.dashboard{display:flex;width:100%;flex:1}.dashboard-sidebar{width:200px;min-width:200px;background:#faf6f1;border-right:1px solid #e0e0e0;padding:16px 0}.sidebar-item{padding:12px 20px;margin:0 12px;cursor:pointer;transition:all .2s;color:#333}.sidebar-item:hover{background:#e8e8e8}.sidebar-item.active{background:#ff8c42;color:#fff;border-radius:8px}.dashboard-content{flex:1;padding:24px 24px 60px;overflow:auto;display:flex;flex-direction:column}.dashboard-card{background:#fff;border-radius:8px;padding:20px;box-shadow:0 2px 8px #0000001a;flex:1;min-height:0}.dashboard-card h2{margin-bottom:16px;font-size:16px;color:#666}.gender-ratio-chart,.gender-ratio-chart *,.gender-ratio-chart svg,.gender-ratio-chart svg *,.recharts-wrapper,.recharts-wrapper *,.recharts-surface,.recharts-surface *{outline:none!important}.redeem-table{width:100%;border-collapse:collapse;font-size:13px}.redeem-table th,.redeem-table td{padding:2px 8px;text-align:center;color:#333}.redeem-table th{font-weight:500;color:#666;background:#fffbf5;border-bottom:1px solid #eee}.redeem-table th.sortable-header{cursor:pointer;-webkit-user-select:none;user-select:none}.redeem-table th.sortable-header:hover{background:#f5ebe0}.sort-icons{display:inline-flex;flex-direction:column;margin-left:4px;vertical-align:middle;line-height:1}.sort-arrow{font-size:8px;color:#ccc;line-height:1;height:8px}.sort-arrow.active{color:#333}.redeem-table td{height:8px;border-bottom:1px solid #f5f5f5}.redeem-table tbody tr:last-child td{border-bottom:none}.redeem-table tbody tr:hover{background:#fafafa}.redeem-table tbody tr.row-inactive td{color:#999}.code-cell{display:inline-flex;align-items:center;justify-content:center;gap:6px}.code-copy-icon{color:#2196f3;cursor:pointer;opacity:.7;transition:opacity .2s ease}.code-copy-icon:hover{opacity:1}.status-cell{display:inline-flex;align-items:center;justify-content:center;gap:6px}.status-light{width:8px;height:8px;border-radius:50%}.status-light.red{background:#f44336}.status-light.green{background:#4caf50}.toast{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#000000bf;color:#fff;padding:12px 24px;border-radius:8px;font-size:14px;z-index:2000;animation:fadeInOut 2s ease}@keyframes fadeInOut{0%{opacity:0}15%{opacity:1}85%{opacity:1}to{opacity:0}}.pagination{display:flex;justify-content:center;align-items:center;gap:16px;padding:12px 0;border-top:1px solid #eee;margin-top:auto}.pagination-btn{padding:6px 12px;border:1px solid #9C8B7A;border-radius:4px;background:transparent;color:#9c8b7a;font-size:13px;cursor:pointer;transition:all .2s ease}.pagination-btn:hover:not(:disabled){background:#9c8b7a;color:#fff}.pagination-btn:disabled{border-color:#ddd;color:#ccc;cursor:not-allowed}.pagination-info{display:flex;align-items:center;gap:4px;font-size:13px;color:#666}.pagination-input{width:40px;padding:4px 6px;border:1px solid #ddd;border-radius:4px;font-size:13px;text-align:center;color:#333;outline:none}.pagination-input:focus{border-color:#9c8b7a}.pagination-input::-webkit-outer-spin-button,.pagination-input::-webkit-inner-spin-button{appearance:none;margin:0}.pagination-input[type=number]{appearance:textfield}.redeem-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.redeem-header h2{margin:0}.redeem-title-group{display:flex;align-items:center;gap:12px}.refresh-btn{padding:8px 20px;border:1px solid #9C8B7A;border-radius:12px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;background:transparent;color:#9c8b7a}.refresh-btn:hover{background:#9c8b7a;color:#fff}.generate-btn{padding:8px 20px;border:none;border-radius:12px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;background:#4caf50;color:#fff}.generate-btn:hover{background:#45a049}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:16px;padding:32px;position:relative;box-shadow:0 4px 20px #00000026}.generate-modal{width:480px;max-width:90vw;max-height:80vh;overflow:auto;padding-top:48px}.modal-close{position:absolute;top:16px;right:16px;width:28px;height:28px;border:none;background:transparent;font-size:24px;color:#999;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .2s ease}.modal-close:hover{color:#333}.generate-form{display:flex;flex-direction:column;gap:20px}.form-row{display:flex;justify-content:space-between;align-items:center;gap:16px}.form-row label{font-size:14px;color:#333;flex-shrink:0}.form-label-group{position:relative}.form-hint{position:absolute;top:100%;left:2px;margin-top:4px;font-size:10px;color:#4caf50;white-space:nowrap}.form-input{width:120px;height:40px;padding:0 12px;border:1px solid #E5E5E5;border-radius:8px;font-size:14px;color:#333;background:#fafafa;transition:border-color .2s ease;box-sizing:border-box;text-align:center}.form-input:focus{outline:none;border-color:#4caf50;background:#fff}.form-input::placeholder{color:#999}.form-input::-webkit-outer-spin-button,.form-input::-webkit-inner-spin-button{appearance:none;margin:0}.form-input[type=number]{appearance:textfield}.generate-actions{display:flex;justify-content:center;margin-top:32px}.generate-submit-btn{padding:12px 48px;border:none;border-radius:12px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s ease;background:#4caf50;color:#fff}.generate-submit-btn:hover:not(:disabled){background:#45a049}.generate-submit-btn:disabled{background:#ccc;cursor:not-allowed}.generated-header{position:relative;display:flex;justify-content:center;align-items:center;margin-bottom:20px}.generated-title{font-size:16px;font-weight:500;color:#333;margin:0}.copy-all-btn{position:absolute;left:0;display:flex;align-items:center;gap:4px;padding:6px 12px;border:1px solid #2196F3;border-radius:6px;background:transparent;color:#2196f3;font-size:13px;cursor:pointer;transition:all .2s ease}.copy-all-btn:hover{background:#2196f3;color:#fff}.copy-icon{flex-shrink:0}.generated-table-container{max-height:400px;overflow:auto}.expire-inputs{display:flex;align-items:center;gap:4px}.expire-input{width:40px!important}.expire-label{font-size:13px;color:#666;margin-right:8px}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#fffbf5;padding:20px}.login-card{width:100%;max-width:400px;padding:40px 32px;background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014}.login-title{text-align:center;font-size:24px;font-weight:600;color:#333;margin:0 0 32px}.login-tabs{display:flex;background-color:#f5eee6;border-radius:24px;padding:4px;margin-bottom:32px}.login-tab{flex:1;padding:10px 16px;border:none;border-radius:20px;font-size:15px;font-weight:500;cursor:pointer;transition:all .2s ease;background-color:transparent;color:#9c8b7a}.login-tab.active{background-color:#fff;color:#333}.login-form{display:flex;flex-direction:column;gap:20px;margin-bottom:32px}.input-group{display:flex;flex-direction:column}.login-input{width:100%;height:48px;padding:0 16px;border:1px solid #E5E5E5;border-radius:12px;font-size:15px;color:#333;background:#fafafa;transition:border-color .2s ease;box-sizing:border-box}.login-input:focus{outline:none;border-color:#4caf50;background:#fff}.login-input::placeholder{color:#999}.input-with-button{display:flex;align-items:center;gap:12px}.input-with-button .login-input{flex:1}.code-button{white-space:nowrap;padding:0 12px;height:48px;border:none;border-radius:12px;font-size:14px;cursor:pointer;transition:all .2s ease;background:transparent;color:#999}.code-button.active{color:#4caf50;cursor:pointer}.code-button:disabled{cursor:not-allowed}.code-sent-hint{display:block;text-align:right;font-size:12px;color:transparent;margin-top:8px;height:18px;line-height:18px}.code-sent-hint.visible{color:#999}.input-with-icon{position:relative;display:flex;align-items:center}.input-with-icon .login-input{padding-right:48px}.password-toggle{position:absolute;right:16px;cursor:pointer;color:#999;font-size:18px;display:flex;align-items:center;justify-content:center;transition:color .2s ease}.password-toggle:hover{color:#666}.forgot-password{display:inline-block;font-size:12px;color:#4caf50;cursor:pointer;margin-top:8px;padding-left:4px;height:18px;line-height:18px}.forgot-password:hover{text-decoration:underline}.login-button{width:100%;height:48px;border:none;border-radius:12px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s ease;background:#4caf50;color:#fff}.login-button:hover:not(:disabled){background:#45a049}.login-button:disabled{background:#ccc;cursor:not-allowed}.app{min-height:100vh;display:flex;flex-direction:column;position:relative}.app-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background:#fffbf5;color:#9c8b7a;border-bottom:1px solid #9C8B7A;-webkit-app-region:drag}.app-header h1{margin:0;font-size:1.5rem}.header-right{display:flex;align-items:center;gap:16px}.version{font-size:.875rem;opacity:.8}.logout-button{padding:6px 16px;border:1px solid #9C8B7A;border-radius:6px;background:transparent;color:#9c8b7a;font-size:14px;cursor:pointer;transition:all .2s ease;-webkit-app-region:no-drag}.logout-button:hover{background:#9c8b7a;color:#fff}.app-main{flex:1;display:flex}.welcome{text-align:center}.welcome h2{color:#333;margin-bottom:1rem}.welcome p{color:#666;margin:.5rem 0}.app-footer{position:absolute;bottom:0;left:0;right:0;padding:.5rem 2rem;text-align:center;color:#999;font-size:.875rem}
