.loyalty-card{background:#f4f3ee;color:#3a3a3a;padding:24px;border-radius:24px;box-shadow:0 4px 20px #0000001a;text-align:center;max-width:380px;margin:auto;font-family:Poppins,sans-serif}.header h2{font-family:Playfair Display,serif;color:#6b705c;margin:0}.progress{margin:16px 0}.bar{height:8px;width:80%;background:#d6e2d0;border-radius:999px;margin:0 auto 8px}.fill{height:100%;background:linear-gradient(90deg,#9ec8a8,#cddfcf);border-radius:999px;transition:width .5s ease}.stamps{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;justify-items:center;margin-top:12px}.stamp{width:58px;height:58px;border:2px dashed #cddfcf;border-radius:14px;display:flex;align-items:center;justify-content:center;font-weight:600;color:#8b8b8b}.stamp.active{background:linear-gradient(135deg,#9ec8a8,#cddfcf);color:#fff;border:none}.reward{margin-top:16px;font-size:.95rem;color:#6b705c}.qr-generator{background:#ffd500;border-radius:20px;padding:24px;max-width:360px;margin:24px auto;box-shadow:0 4px 20px #0000001a;text-align:center;font-family:Poppins,sans-serif}.qr-generator h2{color:#6b705c;font-family:Playfair Display,serif}.redeem-container input{padding:10px 12px;border-radius:10px;border:1px solid #e0b1cb;background:#fff;font-size:1rem;outline:none;text-align:center;text-transform:uppercase;width:100%;transition:border-color .2s ease;margin-bottom:18px;box-shadow:0 1px 3px #00000008}.qr-generator label{display:block;margin-top:12px;color:#3a3a3a;font-size:.9rem;text-align:left}.qr-generator input{width:100%;padding:10px;border-radius:8px;border:1px solid #cddfcf;margin-top:4px;outline:none;font-size:1rem}.qr-generator button{background:linear-gradient(90deg,#9ec8a8,#cddfcf);color:#fff;font-weight:600;border:none;border-radius:10px;padding:10px 20px;margin-top:16px;cursor:pointer;transition:transform .2s ease}.qr-generator button:hover{transform:scale(1.03)}.qr-preview{margin-top:20px}.create-client-container{background:#f9f8f3;border-radius:16px;box-shadow:0 6px 20px #0000000d;max-width:400px;margin:40px auto;padding:30px 25px;font-family:Poppins,sans-serif;text-align:center;color:#5e4b47}.create-client-container h2{color:#6b705c;margin-bottom:20px}form{display:flex;flex-direction:column;gap:15px}label{font-weight:500;text-align:left;color:#6b705c}input{padding:10px 12px;border-radius:10px;border:1px solid #6b705c;background:#fff;font-size:1rem;outline:none;transition:border-color .2s ease}input:focus{border-color:#6b705c}button{background:#6b705c;color:#fff;border:none;border-radius:10px;padding:10px 0;font-weight:600;cursor:pointer;transition:.2s ease}.message{margin-top:15px;font-weight:500}.message.success{color:#2e7d32}.message.error{color:#c62828}.client-card-container{background:#f9f8f3;border-radius:16px;box-shadow:0 6px 20px #0000000d;max-width:400px;margin:40px auto;padding:30px;font-family:Poppins,sans-serif;text-align:center;color:#5e4b47}h2{color:#6b705c;margin-bottom:10px}.slots{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin:20px 0}.slot{width:50px;height:50px;border-radius:50%;border:2px solid #6b705c}.slot.filled{background-color:#6b705c}button{background:#6b705c;color:#fff;border:none;border-radius:10px;padding:10px 18px;font-weight:600;cursor:pointer;transition:.2s ease}.reward{margin-top:20px;background:#fff;padding:15px;border-radius:12px;border:1px solid #6b705c}.code{font-size:1.4rem;font-weight:700;background:#6b705c;color:#fff;border-radius:8px;padding:10px;margin:10px 0}.msg{margin-top:10px}.redeem-container{background:#f9f8f3;border-radius:16px;box-shadow:0 6px 20px #0000000d;max-width:400px;margin:60px auto;padding:30px 25px;font-family:Poppins,sans-serif;text-align:center;color:#5e4b47}.redeem-container h2{color:#6b705c;margin-bottom:10px}.redeem-container p{margin-bottom:15px;color:#6b4f4f}input{padding:10px 12px;border-radius:10px;border:1px solid #e0b1cb;background:#fff;font-size:1rem;outline:none;text-align:center;text-transform:uppercase;width:100%;transition:border-color .2s ease}input:focus{border-color:#f48fb1}button{background:#6b705c;color:#fff;border:none;border-radius:10px;padding:10px 0;width:100%;font-weight:600;margin-top:15px;cursor:pointer;transition:.2s ease}button:hover{opacity:.9}.msg{margin-top:15px;font-weight:500}.msg.success{color:#2e7d32}.msg.error{color:#c62828}
