*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:#f5f5f5;color:#333}.app{min-height:100vh;display:flex;flex-direction:column}.navbar{background:linear-gradient(135deg,#d32027 0%,#a01a1f 100%);padding:1rem 2rem;box-shadow:0 2px 8px #0000001a}.nav-logo{color:#fff;text-decoration:none;font-size:1.5rem;font-weight:700}.home-page{padding:2rem;max-width:1400px;margin:0 auto;width:100%}.banner{background:linear-gradient(135deg,#d32027 0%,#a01a1f 100%);color:#fff;padding:3rem 2rem;border-radius:12px;text-align:center;margin-bottom:2rem;box-shadow:0 4px 12px #d320274d}.banner h1{font-size:2.5rem;margin-bottom:.5rem}.banner p{font-size:1.2rem;opacity:.95}.tickets-section h2{font-size:1.8rem;margin-bottom:1.5rem;color:#d32027}.tickets-scroll{display:flex;overflow-x:auto;gap:1.5rem;padding:1rem 0;scroll-behavior:smooth}.tickets-scroll::-webkit-scrollbar{height:8px}.tickets-scroll::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.tickets-scroll::-webkit-scrollbar-thumb{background:#d32027;border-radius:4px}.ticket-card{min-width:280px;background:white;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000001a;transition:transform .2s,box-shadow .2s}.ticket-card:hover{transform:translateY(-4px);box-shadow:0 4px 16px #d3202733}.ticket-image{width:100%;aspect-ratio:16/9;object-fit:cover;display:block}.ticket-content{padding:1.5rem}.ticket-card h3{font-size:1.1rem;margin-bottom:.5rem;color:#333;min-height:3rem;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.limited-tag{display:inline-block;background:#ff9800;color:#fff;font-size:.75rem;padding:.25rem .5rem;border-radius:4px;font-weight:700}.ticket-price{font-size:1.8rem;font-weight:700;color:#d32027;margin:1rem 0;display:flex;align-items:center;gap:.75rem}.original-price{font-size:1.2rem;color:#999;text-decoration:line-through;font-weight:400}.current-price{color:#d32027}.btn-order{width:100%;padding:.8rem;background:#d32027;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:700;cursor:pointer;transition:background .2s}.btn-order:hover{background:#a01a1f}.promo-section{margin-top:3rem;padding:2rem;background:white;border-radius:12px;box-shadow:0 2px 8px #0000001a}.promo-section h2{color:#d32027;margin-bottom:1rem}.promo-placeholder{color:#666;font-style:italic}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);display:flex;justify-content:center;align-items:flex-start;padding-top:5vh;z-index:1000}.modal-content{background:white;padding:2rem;border-radius:12px;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 8px 24px #0000004d}.modal-content h2{margin-bottom:1.5rem;color:#d32027}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500}.form-group input{width:100%;padding:.8rem;border:2px solid #ddd;border-radius:8px;font-size:1rem}.form-group input:focus{outline:none;border-color:#d32027}.error-text{color:#d32027;margin-top:.5rem;font-size:.9rem}.modal-actions{display:flex;gap:1rem;justify-content:flex-end}.btn-primary,.btn-secondary{padding:.8rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s}.btn-primary{background:#d32027;color:#fff}.btn-primary:hover{background:#a01a1f}.btn-secondary{background:#e0e0e0;color:#333}.btn-secondary:hover{background:#d0d0d0}.order-page{padding:2rem;max-width:800px;margin:0 auto}.order-page h1{color:#d32027;margin-bottom:2rem;text-align:center}.ticket-category{margin-bottom:2rem}.ticket-category h2{color:#d32027;margin-bottom:1rem;font-size:1.5rem}.ticket-box{background:white;border:2px solid #e0e0e0;border-radius:12px;padding:1.5rem;margin-bottom:1rem;box-shadow:0 2px 8px #00000014;transition:opacity .2s}.ticket-box.disabled{opacity:.5;background:#f5f5f5;border-color:#ccc}.ticket-box.disabled *{color:#999!important;cursor:not-allowed}.ticket-top-row{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem}.ticket-box-image{width:200px;max-width:40%;flex-shrink:0;aspect-ratio:16/9;object-fit:cover;border-radius:8px}.ticket-details{flex:1}.ticket-details h3{font-size:1.2rem;color:#333;margin-bottom:.3rem;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.ticket-english{font-size:.9rem;color:#666;margin-bottom:1rem}.ticket-info{margin-bottom:1rem}.ticket-info .ticket-price{font-size:1.5rem;font-weight:700;color:#d32027;margin-bottom:.5rem;display:flex;align-items:center;gap:.75rem}.ticket-info .original-price{font-size:1.1rem;color:#999;text-decoration:line-through;font-weight:400}.ticket-info .current-price{color:#d32027}.ticket-status{color:#4caf50;margin-bottom:.3rem}.ticket-sale-end{color:#666;font-size:.9rem}.ticket-description{margin-bottom:1rem}.ticket-description p{white-space:pre-wrap;line-height:1.6;color:#555;font-size:.95rem}.ticket-description p.collapsed{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.ticket-description p.expanded{display:block}.see-more-btn{background:none;border:none;color:#d32027;cursor:pointer;font-size:.9rem;padding:.5rem 0;text-decoration:underline}.quantity-controls{display:flex;align-items:center;justify-content:flex-end;gap:1rem}.qty-btn{width:40px;height:40px;border:2px solid #d32027;background:white;color:#d32027;border-radius:8px;font-size:1.5rem;cursor:pointer;transition:all .2s;font-weight:700}.qty-btn:hover:not(:disabled){background:#d32027;color:#fff}.qty-btn:disabled{border-color:#ccc;color:#ccc;cursor:not-allowed;background:#f5f5f5}.quantity{font-size:1.2rem;font-weight:700;min-width:40px;text-align:center}.total-section{background:#f9f9f9;padding:1.5rem;border-radius:12px;margin:2rem 0}.total-section h2{color:#d32027;font-size:1.8rem;margin-bottom:1rem}.order-breakdown{background:white;padding:1rem;border-radius:8px}.breakdown-item{display:flex;justify-content:space-between;align-items:center;padding:.8rem 0;border-bottom:1px solid #e0e0e0}.breakdown-item:last-of-type{border-bottom:2px solid #d32027}.breakdown-name{flex:1;font-size:.95rem;color:#333}.breakdown-qty{color:#666;margin:0 1rem;font-size:.9rem}.breakdown-price{font-weight:700;color:#d32027}.breakdown-total{display:flex;justify-content:space-between;align-items:center;padding:1rem 0 0;font-size:1.2rem;font-weight:700}.total-amount{color:#d32027;font-size:1.5rem}.no-items{color:#999;text-align:center;padding:1rem;font-style:italic}.form-section{background:white;padding:1.5rem;border-radius:12px;margin-bottom:2rem;box-shadow:0 2px 8px #00000014}.form-section h2{color:#d32027;margin-bottom:1rem}.checkbox-group{display:flex;align-items:center}.checkbox-group label{display:flex;align-items:center;cursor:pointer}.checkbox-group input[type=checkbox]{width:auto;margin-right:.5rem;cursor:pointer}.checkbox-group span{font-weight:500}.radio-group{display:flex;gap:2rem}.radio-group label{display:flex;align-items:center;cursor:pointer}.radio-group input[type=radio]{width:auto;margin-right:.5rem;cursor:pointer}.checkbox-services{display:flex;flex-direction:column;gap:.8rem}.checkbox-services label{display:flex;align-items:center;cursor:pointer}.checkbox-services input[type=checkbox]{width:auto;margin-right:.5rem;cursor:pointer}.btn-submit{width:100%;padding:1rem;background:#d32027;color:#fff;border:none;border-radius:8px;font-size:1.2rem;font-weight:700;cursor:pointer;transition:background .2s}.btn-submit:hover{background:#a01a1f}.submit-modal{max-width:600px}.modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:2rem;cursor:pointer;color:#666;line-height:1}.modal-close:hover{color:#333}.submit-step{margin-bottom:2rem;padding:1.5rem;background:#f9f9f9;border-radius:8px}.submit-step h3{color:#d32027;margin-bottom:1rem}.submit-step p{margin-bottom:1rem;color:#555}.btn-whatsapp,.btn-whatsapp-secondary{display:block;width:100%;padding:1rem;background:#25D366;color:#fff;text-decoration:none;text-align:center;border-radius:8px;font-weight:700;transition:background .2s}.btn-whatsapp:hover{background:#20BA5A}.btn-whatsapp-secondary{background:#128C7E}.btn-whatsapp-secondary:hover{background:#0F7A6E}.payment-info{background:white;padding:1rem;border-radius:8px;margin:1rem 0}.payment-item{display:flex;align-items:center;gap:.5rem;padding:.8rem 0;border-bottom:1px solid #e0e0e0}.payment-item:last-child{border-bottom:none}.payment-label{font-weight:500;color:#333;min-width:100px}.payment-fps{flex:1;display:flex;flex-direction:column;gap:.25rem}.payment-value{font-weight:700;color:#d32027}.payment-recipient{font-size:.85rem;color:#666}.payme-link{flex:1;color:#d32027;text-decoration:none;font-weight:700}.payme-link:hover{text-decoration:underline}.copy-btn{padding:.5rem 1rem;background:#f0f0f0;border:1px solid #ddd;border-radius:6px;cursor:pointer;font-size:.85rem;transition:all .2s;white-space:nowrap}.copy-btn:hover{background:#e0e0e0}.payment-note{color:#666;font-size:.9rem;margin:1rem 0;text-align:center}.ticket-delivery-info{background:#e8f5e9;padding:1rem;border-radius:8px;margin-top:1rem;color:#2e7d32;font-size:.95rem;line-height:1.6;border-left:4px solid #4caf50}.btn-complete{width:100%;padding:1rem;background:#4caf50;color:#fff;border:none;border-radius:8px;font-size:1.1rem;font-weight:700;cursor:pointer;transition:background .2s;margin-top:1.5rem}.btn-complete:hover{background:#45a049}.btn-complete.disabled,.btn-complete:disabled{background:#ccc;cursor:not-allowed;opacity:.6}.btn-complete.disabled:hover,.btn-complete:disabled:hover{background:#ccc}.complete-hint{text-align:center;color:#f44336;font-size:.95rem;margin-top:.5rem;font-weight:500}@media (max-width: 768px){.banner h1{font-size:2rem}.ticket-card{min-width:240px}.order-page{padding:1rem}.payment-item{flex-wrap:wrap}.payment-label{min-width:80px}}@media (max-width: 600px){.ticket-top-row{flex-direction:column;align-items:stretch}.ticket-box-image{width:100%;max-width:100%;margin-bottom:1rem}.quantity-controls{justify-content:center}}
