*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem}.login-container{background:#fff;border-radius:20px;padding:2.5rem 2rem;width:100%;max-width:400px;box-shadow:0 20px 60px #0000004d}.login-header{text-align:center;margin-bottom:2rem}.login-icon{font-size:4rem;margin-bottom:1rem}.login-title{font-size:1.75rem;color:#1f2937;margin-bottom:.5rem}.login-subtitle{color:#6b7280;font-size:.9375rem}.login-form{display:flex;flex-direction:column;gap:1rem}.login-input{padding:1rem;border:2px solid #e5e7eb;border-radius:12px;font-size:1rem;transition:all .2s}.login-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.login-btn{padding:1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:1.0625rem;font-weight:600;cursor:pointer;transition:transform .2s}.login-btn:active{transform:scale(.98)}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-footer{margin-top:1.5rem;text-align:center;color:#9ca3af;font-size:.875rem}.app{min-height:100vh;padding:1rem}.container{max-width:800px;margin:0 auto;padding-bottom:2rem}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.title{color:#fff;font-size:1.75rem;font-weight:700;text-shadow:0 2px 4px rgba(0,0,0,.2)}.logout-btn{background:#fff3;color:#fff;border:2px solid rgba(255,255,255,.3);padding:.625rem 1.25rem;border-radius:10px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s}.logout-btn:hover{background:#ffffff4d}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem}.stat-card{background:#fff;border-radius:16px;padding:1.25rem;display:flex;align-items:center;gap:1rem;box-shadow:0 4px 6px #0000001a}.stat-card.stat-available{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.stat-card.stat-used{background:#f3f4f6}.stat-icon{font-size:2rem}.stat-info{flex:1}.stat-value{font-size:1.875rem;font-weight:700;line-height:1;margin-bottom:.25rem}.stat-label{font-size:.875rem;opacity:.8}.main-card{background:#fff;border-radius:16px;padding:0;margin-bottom:1rem;box-shadow:0 4px 6px #0000001a;overflow:hidden}.card-header{padding:1.25rem 1.5rem;border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;align-items:center}.card-title{font-size:1.125rem;font-weight:600;color:#1f2937}.card-body{padding:1.5rem}.close-btn{background:#ef4444;color:#fff;border:none;border-radius:50%;width:28px;height:28px;font-size:1.125rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.close-btn:hover{background:#dc2626}.form-group{margin-bottom:1.25rem}.form-label{display:block;font-size:.875rem;font-weight:600;color:#374151;margin-bottom:.5rem}.form-input{width:100%;padding:.875rem 1rem;border:2px solid #e5e7eb;border-radius:10px;font-size:1rem;transition:all .2s}.form-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-input:disabled{background:#f9fafb;cursor:not-allowed}.form-textarea{width:100%;padding:.875rem 1rem;border:2px solid #e5e7eb;border-radius:10px;font-size:1rem;font-family:inherit;resize:vertical;transition:all .2s}.form-textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-textarea:disabled{background:#f9fafb;cursor:not-allowed}.extract-form{display:flex;flex-direction:column;gap:1rem}.btn{padding:.75rem 1.5rem;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:active:not(:disabled){transform:scale(.98)}.btn-large{width:100%;padding:1rem;font-size:1.0625rem}.btn-icon{font-size:1.25rem}.btn-copy-small{padding:.5rem .75rem;background:#667eea;color:#fff;border:none;border-radius:8px;font-size:.875rem;cursor:pointer;white-space:nowrap}.result-card{background:#fff;border-radius:16px;padding:0;margin-bottom:1rem;box-shadow:0 4px 6px #0000001a;overflow:hidden}.result-item{display:flex;gap:1rem;padding:1.25rem;border-bottom:1px solid #f3f4f6}.result-item:last-child{border-bottom:none}.result-number{background:#667eea;color:#fff;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;flex-shrink:0}.result-content{flex:1;min-width:0}.result-label{font-size:.75rem;color:#6b7280;margin-bottom:.25rem}.result-value{font-size:.875rem;color:#374151;margin-bottom:.75rem;word-break:break-all}.result-code{font-size:1.125rem;font-weight:600;color:#1f2937;font-family:Courier New,monospace;word-break:break-all}.action-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;margin-bottom:1rem}.action-btn{background:#fff;border:2px solid #e5e7eb;border-radius:12px;padding:1rem;display:flex;flex-direction:column;align-items:center;gap:.5rem;cursor:pointer;transition:all .2s}.action-btn:hover:not(:disabled){border-color:#667eea;background:#f9fafb}.action-btn:disabled{opacity:.5;cursor:not-allowed}.action-btn.action-danger:hover:not(:disabled){border-color:#ef4444;background:#fef2f2}.action-icon{font-size:1.5rem}.action-text{font-size:.875rem;font-weight:600;color:#374151}.code-list{display:flex;flex-direction:column;gap:.75rem;max-height:400px;overflow-y:auto}.list-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#f9fafb;border-radius:10px;transition:all .2s}.list-item.used{opacity:.6}.list-content{flex:1;min-width:0}.list-code{font-size:1rem;font-weight:600;color:#1f2937;font-family:Courier New,monospace;word-break:break-all}.list-time{font-size:.75rem;color:#6b7280;margin-top:.25rem}.list-status{font-size:1.5rem;color:#10b981;flex-shrink:0;margin-left:1rem}.history-list{display:flex;flex-direction:column;gap:1rem;max-height:500px;overflow-y:auto}.history-item{background:#f9fafb;border-radius:12px;padding:1.25rem;border:1px solid #e5e7eb}.history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;flex-wrap:wrap;gap:.5rem}.history-time{font-size:.875rem;color:#6b7280;font-weight:500}.history-count{font-size:.875rem;color:#667eea;font-weight:600}.history-note{font-size:.875rem;color:#374151;margin-bottom:.75rem;padding:.5rem;background:#fff;border-radius:6px}.history-codes{margin-top:.75rem}.history-codes-title{font-size:.75rem;color:#6b7280;font-weight:600;margin-bottom:.5rem}.history-code-item{display:flex;gap:.5rem;padding:.5rem;background:#fff;border-radius:6px;margin-bottom:.5rem}.history-code-number{color:#667eea;font-weight:600;font-size:.875rem;flex-shrink:0}.history-code-text{font-family:Courier New,monospace;font-size:.875rem;color:#1f2937;word-break:break-all}.empty-card{background:#fff;border-radius:16px;padding:3rem 2rem;text-align:center;box-shadow:0 4px 6px #0000001a}.empty-icon{font-size:4rem;margin-bottom:1rem}.empty-text{font-size:1.25rem;font-weight:600;color:#1f2937;margin-bottom:.5rem}.empty-hint{font-size:.875rem;color:#6b7280}@media(max-width:640px){.stats-grid,.action-grid{grid-template-columns:1fr}.title{font-size:1.25rem}.result-item{flex-direction:column;align-items:flex-start}.btn-copy-small{align-self:flex-end}}
