.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.7);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:white;border-radius:20px;max-width:500px;width:100%;max-height:90vh;overflow:hidden;position:relative;animation:slideUp .3s ease;display:flex;flex-direction:column}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-close{position:absolute;top:20px;right:20px;width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.6);border:1px solid rgba(226,232,240,.5);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;z-index:10;backdrop-filter:blur(8px)}.modal-close:hover{background:rgba(248,250,252,.85);transform:scale(1.1)}.modal-close span{font-size:20px;font-weight:700;color:#333}.modal-image{width:100%;height:250px;background:#f8fafc;overflow:hidden;position:relative;flex-shrink:0}.modal-image.no-crop{height:auto;max-height:400px;flex-shrink:0}.modal-image img{width:100%;height:100%;object-fit:cover}.modal-image.no-crop img{height:auto;max-height:400px;object-fit:contain}.image-disclaimer-modal{position:absolute;bottom:8px;left:8px;background:rgba(0,0,0,.7);color:white;padding:4px 8px;border-radius:4px;font-size:11px;font-weight:500}.modal-body{padding:30px;overflow-y:auto;flex:1;min-height:0}.discount-badge-large{display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#ff6b6b,#ff8787);color:white;padding:12px 24px;border-radius:50px;font-size:24px;font-weight:800;margin-bottom:20px;box-shadow:0 4px 12px rgba(255,107,107,.3);letter-spacing:.5px}.modal-title{font-size:24px;font-weight:700;color:#1e293b;margin-bottom:12px;line-height:1.3}.modal-description{font-size:16px;color:#64748b;line-height:1.6;margin-bottom:30px}.conditions-section,.store-section,.validity-section{margin-bottom:25px}.conditions-section h3,.store-section h3,.validity-section h3{font-size:14px;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}.store-card-link{text-decoration:none}.store-card{display:flex;align-items:center;gap:12px;padding:16px;background:#f8fafc;border-radius:12px;transition:all .2s;cursor:pointer}.store-card:hover{background:#f1f5f9;transform:translateX(4px)}.store-icon{font-size:24px}.store-name{flex:1;font-size:16px;font-weight:600;color:#1e293b}.arrow{font-size:16px;color:#94a3b8}.conditions-section p,.validity-section p{font-size:15px;color:#475569;line-height:1.6}.point-section{display:flex;align-items:center;justify-content:center;gap:8px;padding:16px;background:#fef3c7;border-radius:12px;margin-bottom:25px}.point-icon{font-size:24px}.point-cost{font-size:20px;font-weight:700;color:#92400e}.modal-actions{margin-top:30px}.use-confirm{background:#f8fafc;border-radius:16px;padding:24px;text-align:center}.use-confirm p{font-size:18px;font-weight:600;color:#1e293b;margin-bottom:8px}.confirm-note{font-size:14px;color:#64748b;margin-bottom:20px}.confirm-actions{display:flex;gap:12px;justify-content:center}.cancel-btn,.use-btn{padding:14px 28px;border-radius:12px;font-size:16px;font-weight:600;border:none;cursor:pointer;transition:all .2s}.cancel-btn{background:#e2e8f0;color:#475569}.cancel-btn:hover:not(:disabled){background:#cbd5e1;transform:translateY(-1px)}.use-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:white;width:100%}.use-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 16px rgba(102,126,234,.4)}.use-btn.confirm{width:auto;background:linear-gradient(135deg,#f59e0b,#d97706)}.use-btn.confirm:hover:not(:disabled){box-shadow:0 4px 16px rgba(245,158,11,.4)}.cancel-btn:disabled,.use-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.acquire-btn.primary{width:100%;padding:16px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:white;border:none;border-radius:12px;font-size:16px;font-weight:700;cursor:pointer;transition:all .2s}.acquire-btn.primary:hover{transform:translateY(-2px);box-shadow:0 4px 16px rgba(102,126,234,.4)}.status-message{display:flex;align-items:center;justify-content:center;gap:8px;padding:16px;border-radius:12px;font-size:16px;font-weight:600}.status-message.used{background:#e2e8f0;color:#64748b}.status-message.expired{background:#fee2e2;color:#dc2626}.tomorrow-note{font-size:12px;color:#92400e;margin-top:8px;display:block}.use-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(255,255,255,.95);display:flex;align-items:center;justify-content:center;z-index:20;animation:fadeIn .3s ease}.use-animation{text-align:center}.checkmark{width:80px;height:80px;background:linear-gradient(135deg,#10b981,#059669);color:white;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:48px;font-weight:700;margin:0 auto 20px;animation:scaleIn .4s ease;box-shadow:0 8px 24px rgba(16,185,129,.3)}@keyframes scaleIn{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}.use-animation p{font-size:24px;font-weight:700;color:#10b981;animation:slideUpText .5s ease .2s both}@keyframes slideUpText{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.close-button{width:100%;padding:16px;background:#f1f5f9;color:#475569;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;margin-top:16px}.close-button:hover{background:#e2e8f0;transform:translateY(-1px)}@media (max-width:768px){.modal-body{padding:20px}.modal-title{font-size:20px}.discount-badge-large{font-size:20px;padding:10px 20px}.confirm-actions{flex-direction:column}.cancel-btn,.use-btn.confirm{width:100%}}