/* Reset y utilidades */
*{box-sizing:border-box;margin:0;padding:0}
body{font-family: 'Inter', 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif; color:#222; background:#f6f7f8; -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale; line-height:1.45; touch-action: manipulation}
.container{width:1100px;max-width:94%;margin:0 auto}

/* Login card improvements */
.login-card{max-width:420px;margin:0 auto;background:#fff;padding:34px;border-radius:12px;box-shadow:0 12px 40px rgba(16,24,40,0.08);}
.login-card h2{margin-bottom:12px;font-size:22px}
.login-card .form-row{margin-bottom:12px}
.login-card input{width:100%;padding:12px 14px;border:1px solid #eef2f6;border-radius:10px;background:#fff;font-size:15px}
.login-card .error{color:#c33;margin-top:12px;display:none}
.btn-loading{opacity:0.8;pointer-events:none}

/* Toast notifications */
.toast-container{position:fixed;right:20px;top:20px;z-index:99999;display:flex;flex-direction:column;gap:10px}
.toast{min-width:260px;max-width:360px;padding:12px 14px;border-radius:10px;color:#fff;box-shadow:0 8px 30px rgba(2,6,23,0.12);display:flex;align-items:flex-start;gap:10px;font-size:14px}
.toast .toast-close{margin-left:auto;background:transparent;border:none;color:inherit;cursor:pointer;font-size:16px}
.toast--success{background:linear-gradient(90deg,#06ad5e,#00c47a)}
.toast--error{background:linear-gradient(90deg,#ff5f5f,#d93a3a)}
.toast--info{background:linear-gradient(90deg,#2f80ed,#2bb6ff)}
.toast .icon{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;opacity:0.95}

/* Header */
.header{position: sticky;top: 0px;}
.site-header{background:#fff;border-bottom:1px solid #eee;position:sticky;top:0;z-index:100}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 0;gap:16px;min-height:64px}
.brand{display:flex;align-items:center;gap:12px}
.logo-circle{width:44px;height:44px;border-radius:50%;background:#e33;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700}
.brand-name{font-weight:700}
.main-nav{display:flex;align-items:center;justify-content:center;gap:16px;flex:1 1 auto}
.main-nav a{margin:0;color:#666;text-decoration:none;font-size:14px}
.buy-btn{background:#e33;color:#fff;border:none;padding:10px 18px;border-radius:24px;cursor:pointer;flex:0 0 auto;white-space:nowrap}

/* Hero */
.hero{padding:36px 0 18px;text-align:center}
.hero h1{font-size:64px;letter-spacing:2px;margin-bottom:6px;color:#111;font-weight:800}
.brand-name, .title, .card-title, .modal-title, h1, h2, h3, h4, h5, h6 {font-family: 'Poppins', 'Inter', 'Segoe UI', sans-serif}
.subtitle{color:#6d6d6d}

/* Support Section */
.support-section{padding:40px 0;background:#fff;border-top:1px solid #eee;text-align:center}
.support-section h2{font-size:28px;color:#e33;margin-bottom:10px;font-weight:700}
.support-section p{font-size:16px;color:#666;margin-bottom:20px}
.whatsapp-btn{background:#e33;color:#fff;padding:12px 24px;border-radius:24px;text-decoration:none;font-weight:700;display:inline-flex;align-items:center;gap:8px;transition:background 0.3s}
.whatsapp-btn:hover{background:#c22}
.whatsapp-btn i{font-size:18px}

/* Cards */
.cards{display:flex; gap:30px;flex-wrap:wrap;justify-content:center;margin-bottom:36px}
.card{background:#fff;border-radius:12px;box-shadow:0 6px 18px rgba(0,0,0,0.08);overflow:hidden;position:relative;max-width: 50%;}
.card .media{height:220px;background:#ddd;position:relative}
.card img{width:100%;height:100%;object-fit:cover;display:block}
.price-badge{position:absolute;right:14px;top:14px;background:#e33;color:#fff;padding:8px 12px;border-radius:20px;font-weight:700}

.card .content{padding:18px}
.meta{color:#e33;display:flex;gap:12px;align-items:center;margin-bottom:10px;font-size:14px}
.title{font-weight:800;margin-bottom:8px}
.description{color:#444;font-size:13px;font-weight:600;margin-bottom:8px}
.details{color:#666;font-size:14px;margin-bottom:12px}
.footer-row{display:flex;align-items:center;justify-content:space-between;padding:12px 18px 22px}

/* Progress bar */
.container-progress{flex:1}
.progress-label{font-size:13px;color:#666;margin-right:12px;white-space:nowrap}
.progress-bar{height:15px;background:#f0f0f0;border-radius:4px;overflow:hidden;margin-right:12px;box-shadow:inset 0 1px 2px rgba(0,0,0,0.1)}
.progress-bar .progress{height:100%;background:#e33;width:0;transition:width 0.4s ease}

/* Venta boton */
.vermas{background:#e33;color:#fff;padding:10px 18px;border-radius:20px;border:none;cursor:pointer}

/* Info text social*/
.container2 {
  width: 100%;
  max-width: 800px;
  text-align: center;
}

.title2 {
  color: #333;
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 20px;
  position: relative;
  padding-bottom: 15px;
}

.title2:after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 80px;
  height: 4px;
  background: linear-gradient(to right, #e33, #ff6b6b);
  border-radius: 2px;
}

.social-grid {
  display: flex;
  gap: 20px;
  justify-content: center;
  flex-wrap: wrap;
}

.social-card {
  background: white;
  border-radius: 15px;
  box-shadow: 0 5px 10px rgba(0, 0, 0, 0.08);
  padding: 10px 20px;
  transition: all 0.3s ease;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  color: #555;
  position: relative;
  overflow: hidden;
}

.social-card:before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 5px;
  transform: scaleX(0);
  transition: transform 0.3s ease;
}

.social-card:hover {
  transform: translateY(-10px);
  box-shadow: 0 15px 30px rgba(0, 0, 0, 0.15);
}

.social-card:hover:before {
  transform: scaleX(1);
}

.social-icon {
  font-size: 20px;
  margin-bottom: 5px;
  transition: all 0.3s ease;
}

.social-card:hover .social-icon {
  transform: scale(1.2);
}

.social-name {
  font-weight: 600;
  font-size: 16px;
  margin-bottom: 5px;
}

.social-user {
  font-size: 14px;
  color: #777;
}

/* Colores específicos para cada red social */
.instagram {
  border-top: 5px solid transparent;
  background: linear-gradient(white, white) padding-box,
              linear-gradient(90deg, #f09433, #e6683c, #dc2743, #cc2366, #bc1888) border-box;
}

.facebook {
  border-top: 5px solid #3b5998;
}

.tiktok {
  border-top: 5px solid #000000;
}

.whatsapp {
  border-top: 5px solid #25D366;
}

.telegram {
  border-top: 5px solid #0088cc;
}

/* Efectos de color al hacer hover */
.instagram:hover {
  background: linear-gradient(45deg, #f09433, #e6683c, #dc2743, #cc2366, #bc1888);
  color: white;
}

.facebook:hover {
  background: #3b5998;
  color: white;
}

.tiktok:hover {
  background: #000000;
  color: white;
}

.whatsapp:hover {
  background: #25D366;
  color: white;
}

.telegram:hover {
  background: #0088cc;
  color: white;
}




/* Tarjeta con panel rojo arriba (estética similar a la izquierda del adjunto) */
.card.alt .media{background:#b91515;display:flex;align-items:center;padding:12px}
.card.alt .media .thumb{width:120px;height:120px;border-radius:8px;overflow:hidden;margin-right:12px}
.card.alt .media .thumb img{width:100%;height:100%;object-fit:cover}
.card.alt .media .info{color:#fff;font-weight:700}

/* Responsivo */
@media(max-width:800px){
  .hero h1{font-size:40px}
  .cards{gap:20px}
}

/* Ajustes móviles: header compacto y cards a ancho completo */
@media (max-width: 768px){
  /* Solo ocultar el texto de marca del header (mantener footer) */
  .site-header .brand-name{display:none}
  .header-inner{padding:10px 0;min-height:56px}
  .main-nav{gap:12px}
  .main-nav a{margin:0;font-size:12px}
  .buy-btn{padding:8px 12px;border-radius:18px;font-size:12px}

  .hero{padding:24px 0 12px;text-align:center}
  .hero h1{font-size:32px}
  .subtitle{font-size:14px}

  .cards{gap:14px}
  .card{max-width:100%;width:100%;margin:0 auto}
  .card .media{height:200px}
  .meta{font-size:12px}
  .title{font-size:18px}
  .description{font-size:12px}
  .details{font-size:12px}
  .progress-bar{height:10px}
  .footer-row{flex-direction:column;align-items:stretch;gap:10px}
  .vermas{width:100%}
}

@media (max-width: 480px){
  .card .media{height:180px}
  .price-badge{top:10px;right:10px;padding:6px 10px;font-size:12px}
}

/* Modal - mid */
.modal-mid{position:fixed;inset:0;display:none;align-items:center;justify-content:center;z-index:130}
.modal-mid[aria-hidden="false"]{display:flex}
.modal-mid .modal-overlay{position:absolute;inset:0;background:rgba(0,0,0,0.35)}
.modal-mid .modal-panel{position:relative;background:#fff;border-radius:12px;box-shadow:0 18px 60px rgba(0,0,0,0.25);width:100%;max-width:500px;max-height:90vh;overflow:auto;padding:22px}
.modal-mid h2{font-size:24px;margin-bottom:12px;font-weight:800}
.modal-mid p{color:#444;font-size:14px;line-height:1.6}
.modal-mid .form-row{margin-bottom:12px}
.modal-mid input{width:100%;padding:12px 14px;border:1px solid #ececec;border-radius:10px;background:#fff;font-size:14px;color:#222;box-shadow:inset 0 1px 0 rgba(255,255,255,0.6);margin-top:6px}
.modal-mid input::placeholder{color:#bdbdbd}
.modal-mid input:focus{outline:none;border-color:#e33;box-shadow:0 6px 20px rgba(227,51,51,0.08)}
.modal-mid button{background:#e33;color:#fff;border:none;padding:12px;border-radius:10px;cursor:pointer;font-weight:700;box-shadow:0 8px 20px rgba(227,51,51,0.12); margin-top:12px}
.modal-mid button:active{transform:translateY(1px)}
.modal-mid .modal-close{position:absolute;right:12px;top:12px;border:none;background:transparent;font-size:20px;cursor:pointer;color: #000000;}

/* Modal / detalle */
.modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;z-index:130}
.modal[aria-hidden="false"]{display:flex}
.modal-overlay{position:absolute;inset:0;background:rgba(0,0,0,0.35)}
.modal-panel{position:relative;background:#fff;border-radius:12px;box-shadow:0 18px 60px rgba(0,0,0,0.25);width:100%;max-width:1100px;max-height:90vh;overflow:auto}
.modal-grid{display:grid;grid-template-columns:1fr 380px;gap:24px;padding:22px}
.modal-left{padding:12px}
.modal-image{border-radius:8px;overflow:hidden;height:360px;background:#eee}
.modal-image img{width:100%;height:100%;object-fit:cover;display:block}
.modal-title{font-size:32px;margin:12px 0;font-weight:800}
.modal-right{background:transparent;padding:12px}
.buy-card{background:#fff;border-radius:8px;padding:16px;box-shadow:0 6px 18px rgba(0,0,0,0.04)}

/* Estado de carga del formulario de compra */
.buy-card{position:relative}
.form-loading-overlay{position:absolute;inset:0;background:rgba(255,255,255,0.7);backdrop-filter:saturate(120%) blur(1px);display:none;align-items:center;justify-content:center;gap:10px;z-index:5;border-radius:8px}
.form-loading-overlay.active{display:flex}
.form-loading-overlay .loading-text{font-weight:700;color:#333}
.spinner{width:28px;height:28px;border-radius:50%;border:3px solid #e0e0e0;border-top-color:#e33;animation:spin 0.9s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
button.confirm[disabled]{opacity:.7;cursor:not-allowed}
button.confirm.loading{pointer-events:none}

/* Ticket modal redesign */
.ticket-modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;z-index:140}
.ticket-modal[aria-hidden="false"]{display:flex}
.ticket-panel{position:relative;background:#fff;border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,0.25);max-width:520px;width:92%;padding:20px}
.ticket-header{display:flex;align-items:center;justify-content:center;margin-bottom:8px;position:relative}
.ticket-title{font-size:22px;font-weight:900;color:#b91515}
.ticket-close{position:absolute;right:8px;top:8px;background:#f44336;color:#fff;border:none;width:36px;height:36px;border-radius:10px;cursor:pointer;font-weight:900}
.ticket-close:hover{filter:brightness(0.95)}

.ticket-main{border:1px solid #f0d3d3;border-radius:14px;overflow:hidden;background:linear-gradient(180deg,#fff,#fff);}
.ticket-top{height:10px;background:linear-gradient(90deg,#b91515,#e33)}
.ticket-meta{padding:14px 16px}
.info-list{display:flex;flex-direction:column;gap:8px}
.info-item{display:flex;gap:10px;align-items:center;color:#333;font-weight:600}
.info-item i{color:#b91515;min-width:18px;text-align:center}

.ticket-body{display:flex;align-items:center;justify-content:space-between;padding:16px;border-top:1px dashed #f0d3d3;background:#fffaf9}
.ticket-number-large{font-family:'Poppins','Inter',sans-serif;font-size:42px;font-weight:900;letter-spacing:2px;color:#b91515;background:#fff;border:3px dashed #f1c1c1;padding:10px 16px;border-radius:12px;min-width:140px;text-align:center}
.ticket-info{display:flex;flex-direction:column;align-items:flex-end;gap:8px}
.status-badge{background:#ffe6e4;color:#b91515;border:1px solid #f0b7b1;padding:6px 10px;border-radius:999px;font-weight:800}

.ticket-grid{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px}
.ticket-number{background:#fff;border:1px dashed #f0d3d3;color:#b91515;border-radius:10px;padding:10px 14px;font-weight:800;min-width:80px;text-align:center}

.ticket-actions{display:flex;gap:10px;justify-content:center;margin-top:14px}
.ticket-download{background:#fff;border:1px solid #e33;color:#e33;padding:10px 12px;border-radius:10px;cursor:pointer}
.ticket-download:hover{background:#fff4f4}

/* Formularios: inputs limpios y consistentes */
form#buyForm label{display:block;font-size:13px;color:#444;margin:10px 0 6px;font-weight:600}
/* Aplicar a todos los inputs dentro del formulario (también inputs sin type) */
form#buyForm input, form#buyForm select, form#buyForm textarea{
  width:100%;padding:12px 14px;border:1px solid #ececec;border-radius:10px;background:#fff;font-size:14px;color:#222;box-shadow:inset 0 1px 0 rgba(255,255,255,0.6);margin-top:6px}
form#buyForm input::placeholder{color:#bdbdbd}
form#buyForm input:focus, form#buyForm select:focus, form#buyForm textarea:focus{outline:none;border-color:#e33;box-shadow:0 6px 20px rgba(227,51,51,0.08)}
.phone-row {
  display: flex;
  gap: 10px;
  margin-bottom: 10px;
}

.country-selector {
  position: relative;
  width: 110px;
  margin-top: 6px;
}

.selected-option {
  display: flex;
  align-items: center;
  padding: 11px 8px;
  border: 1px solid #ddd;
  border-radius: 8px;
  cursor: pointer;
  background-color: white;
  transition: all 0.3s ease;
}

.selected-option:hover {
  border-color: #6a11cb;
}

.selected-option.open {
  border-color: #6a11cb;
  box-shadow: 0 0 0 2px rgba(106, 17, 203, 0.2);
}

.flag {
  width: 24px;
  height: 18px;
  margin-right: 10px;
  border-radius: 2px;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.country-code {
  font-weight: 500;
  color: #333;
  font-size: 12px;
}

.dropdown-arrow {
  margin-left: auto;
  transition: transform 0.3s ease;
}

.selected-option.open .dropdown-arrow {
  transform: rotate(180deg);
}

.options-container {
  position: absolute;
  top: 100%;
  left: 0;
  width: 100%;
  background-color: white;
  border: 1px solid #ddd;
  border-radius: 8px;
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.1);
  max-height: 250px;
  overflow-y: auto;
  z-index: 100;
  display: none;
}

.options-container.open {
  display: block;
}

.option {
  display: flex;
  align-items: center;
  padding: 10px 15px;
  cursor: pointer;
  transition: background-color 0.2s;
}

.option:hover {
  background-color: #f5f5f5;
}

.option.selected {
  background-color: #eef2ff;
}

.phone-input {
  flex: 1;
  padding: 12px 15px;
  border: 1px solid #ddd;
  border-radius: 8px;
  font-size: 16px;
  transition: border-color 0.3s;
}

.phone-input:focus {
  outline: none;
  border-color: #6a11cb;
  box-shadow: 0 0 0 2px rgba(106, 17, 203, 0.2);
}

.hidden-select {
  display: none;
}

/* Asegurar que los inputs ocupen todo el ancho disponible dentro de filas ajustadas */
.modal-right .buy-card > form > div, .modal-right .buy-card > form > label{width:100%}

/* Payment card y upload box se alinean y tienen mayor altura */
.payment-card{border:1px solid #f2cfcf;padding:14px;border-radius:8px;margin-bottom:12px;background:#fff}
.payment-card small{color:#a66;display:block;margin-top:6px}
.upload-box{min-height:58px;display:flex;align-items:center;justify-content:center}

/* Por defecto esconder las tarjetas de método y mostrar solo la activa */
.payment-card{display:none}
.payment-card.active{display:block}

/* Reducir borde del modal right para parecer tarjeta */
.modal-right .buy-card{border:1px solid #faf0f0}

/* Upload box mejorado */
.upload-box{border:2px dashed #f0dede;padding:18px;text-align:center;border-radius:8px;margin-bottom:12px;background:linear-gradient(180deg, rgba(255,255,255,0.6), rgba(255,255,255,0.3));color:#a33}
.upload-box:hover{background:linear-gradient(180deg, rgba(255,255,255,0.9), rgba(255,255,255,0.6));border-color:#e3bcbc}

/* Currency buttons */
.currency-row .currency{font-weight:700;text-align:center;max-width: 50px; max-height: 50px; padding: 0px; min-width: 50px; min-height: 50px; display:flex;align-items:center;justify-content:center;border:1px solid #eee;cursor:pointer}
.currency-row .currency:not(.active){background:transparent}
.currency-row .currency img{display:block;height: 100%; width: 100%;border-radius: 8px;}

/* Botón confirmar más prominente */
.confirm{background:#e33;color:#fff;border:none;padding:12px;border-radius:10px;cursor:pointer;font-weight:700;box-shadow:0 8px 20px rgba(227,51,51,0.12)}
.confirm:active{transform:translateY(1px)}

/* pequeño ajuste para labels pequeños dentro de qty */
.qty-display{font-weight:700}
.quantity-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.quantity-stack{display:flex;gap:10px;justify-content:center;margin-bottom:14px}
.quantity-stack button{flex:1;padding:10px 0;border-radius:8px;border:1px solid #eee;background:#fafafa;cursor:pointer;font-size:14px;font-weight:700}
.quantity-stack button:hover{background:#fff4f4;border-color:#e3bcbc}
.quantity-stack button.active{transform:translateY(1px);border: 1px solid #e33;background:rgb(255, 182, 182);color:#060606;border:none;box-shadow:0 6px 20px rgba(227,51,51,0.12)}



.qty-btn{width:44px;height:44px;border-radius:50%;border:none;background:#eee;cursor:pointer;font-size:22px}
.qty-display{text-align:center}
#qtyValue{font-size:20px;margin:0 12px;display:inline-block;width:100px;text-align: center; border: 1px solid #eee;border-radius:8px; background: #fff; padding: 8px;}
#qtyValue:focus{outline:none;border-color:#e33;box-shadow:0 6px 20px rgba(227,51,51,0.08)}
#qtyValue::-webkit-inner-spin-button, #qtyValue::-webkit-outer-spin-button {-webkit-appearance: none; margin: 0;}
.qty-display .small{font-size:12px;color:#888}
.totals{background:#fff4f4;padding:12px;border-radius:8px;margin-bottom:14px}
.tot-row{display:flex;justify-content:space-between;padding:6px 0}
.tot-row.highlight strong{color:#e33}
.currency-row{display:flex;gap:12px;margin-bottom:12px}
.currency{flex:1;padding:12px;border-radius:8px;border:1px solid #eee;background:#fafafa;cursor:pointer}
.currency.active{border-color:#e33;background:#fff0f0}
.payment-card{border:2px solid #f2cfcf;padding:12px;border-radius:8px;margin-bottom:12px}
.upload-box{border:2px dashed #e6e6e6;padding:22px;text-align:center;border-radius:8px;margin-bottom:12px;  background:linear-gradient(180deg, rgba(255,255,255,0.6), rgba(255,255,255,0.3));color:#888;cursor:pointer}

/* Miniatura dentro del upload-box cuando hay imagen */
.upload-box.file-selected{display:flex;gap:12px;align-items:center;justify-content:flex-start;padding:10px}
.upload-box .upload-thumb{width:64px;height:64px;object-fit:cover;border-radius:8px;border:1px solid #eee}
.upload-box .upload-name{font-weight:700;color:#333;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* Toasts */
.toast-container{position:fixed;right:20px;top:20px;z-index:99999;display:flex;flex-direction:column;gap:10px}
.toast{min-width:260px;max-width:420px;padding:12px 14px;border-radius:10px;color:#fff;box-shadow:0 8px 30px rgba(2,6,23,0.12);display:flex;align-items:flex-start;gap:10px;font-size:14px}
.toast .body{flex:1}
.toast .toast-close{margin-left:8px;background:transparent;border:none;color:inherit;cursor:pointer;font-size:16px}
.toast--success{background:linear-gradient(90deg,#06ad5e,#00c47a)}
.toast--error{background:linear-gradient(90deg,#ff5f5f,#d93a3a)}
.toast--info{background:linear-gradient(90deg,#2f80ed,#2bb6ff)}
.toast .icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:700}

/* Ticket modal / card */
.ticket-modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;z-index:140}
.ticket-modal[aria-hidden="false"]{display:flex}
.ticket-panel{background:#fff;border-radius:14px;box-shadow:0 20px 60px rgba(0,0,0,0.25);max-width:420px;width:94%;padding:18px;display:flex;flex-direction:column;gap:12px; max-height: 80%; overflow-y: auto;}
.ticket-header{display:flex;align-items:center;gap:12px}
.ticket-title{font-size:20px;font-weight:800;color:#b91515}
.ticket-grid{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}
.ticket-number{background:linear-gradient(180deg,#fff,#ffecec);border:2px dashed #e0a6a6;border-radius:10px;padding:10px 14px;font-weight:800;color:#b91515;min-width:72px;text-align:center}
.ticket-actions{display:flex;gap:8px;justify-content:center}
.ticket-close{background:#e33;color:#fff;border:none;padding:10px 14px;border-radius:10px;cursor:pointer}
/* botón descargar */
.ticket-download{background:#fff;border:1px solid #e33;color:#e33;padding:8px 12px;border-radius:8px;cursor:pointer}

/* área printable: asegurar fondo blanco y padding adecuado para html2canvas */
.ticket-panel.printable{background:#fff;padding:20px;border-radius:12px}
.ticket-number.printable{box-shadow:0 6px 18px rgba(0,0,0,0.08);border-style:solid}

/* Mejoras: tarjeta estilo boleto con datos del comprador */
.ticket-card{display:flex;gap:12px;align-items:flex-start;padding:12px;border-radius:10px;background:linear-gradient(180deg,#fff,#fffaf9);border:1px solid #f3e6e6}
.ticket-image{width:92px;height:92px;border-radius:8px;overflow:hidden;background:#eee;flex-shrink:0}
.ticket-image img{width:100%;height:100%;object-fit:cover;display:block}
.ticket-details{flex:1}
.status-row{display:flex;justify-content:flex-end}
.status-badge{background:#ffcfcb;color:#8a1a1a;padding:6px 10px;border-radius:999px;font-weight:700;font-size:12px}
.raffle-title{font-weight:800;margin-top:6px;font-size:16px}
.buyer-info{margin-top:8px;font-size:13px;color:#444}
.buyer-info div{margin-top:6px}

/* small responsive adjustments */
@media(max-width:480px){
  .ticket-panel{padding:12px}
  .ticket-image{width:72px;height:72px}
  .ticket-number{min-width:60px;padding:8px}
}

/* Progress fill animation helper (small) */
.progress-bar .progress{transition:width 0.8s cubic-bezier(.2,.9,.2,1)}

/* Estilos para el input de recibo */
.receipt {
  display: none;
}


.confirm{width:100%;padding:12px;background:#e33;color:#fff;border:none;border-radius:10px;cursor:pointer}
.modal-close{position:absolute;right:12px;top:12px;border:none;background:transparent;font-size:20px;cursor:pointer}

@media(max-width:980px){
  .modal-grid{grid-template-columns:1fr; padding: 8px;}
  .modal-right{padding:2px;}
  .modal-image{height:260px}
}

/* Bloquear scroll cuando hay un modal abierto */
body.modal-open{overflow:hidden}

/* Modal VER MÁS: ajuste extra en pantallas pequeñas */
@media(max-width:600px){
  .modal-panel{max-width:96%}
  .modal-image{height:220px}
}


/* Boton flotante whatsapp */
.whatsapp-float{position:fixed;width:60px;height:60px;bottom:40px;right:40px;background-color:#25D366;color:#fff;border-radius:50px;text-align:center;font-size:30px;box-shadow:0 4px 12px rgba(0,0,0,0.3);z-index:1000;display:flex;align-items:center;justify-content:center;text-decoration: none; cursor: pointer;}
.whatsapp-icon{margin-top:4px;}

/* Footer Styles */
.site-footer {
    background: #e33;
    color: #fff;
    padding: 40px 0 20px;
    margin-top: 36px;
}

.footer-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
}

.footer-columns {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 30px;
    margin-bottom: 30px;
}

.footer-brand {
    display: flex;
    align-items: center;
    margin-bottom: 15px;
}

.logo-circle2 {
    width: 40px;
    height: 40px;
    background: #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #e33;
    font-size: 20px;
    font-weight: bold;
    margin-right: 12px;
}

.brand-name2 {
    font-size: 22px;
    font-weight: 700;
    color: #fff;
}

.footer-section h3 {
    font-size: 18px;
    margin-bottom: 15px;
    color: #fff;
    position: relative;
    padding-bottom: 8px;
}

.footer-section h3:after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 40px;
    height: 2px;
    background: #fff;
}

.footer-section p {
    margin-bottom: 12px;
    line-height: 1.5;
    opacity: 0.9;
}

.footer-links {
    list-style: none;
}

.footer-links li {
    margin-bottom: 8px;
}

.footer-links a {
    color: #fff;
    text-decoration: none;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
}

.footer-links a:hover {
    color: #ffd700;
    text-decoration: underline;
    transform: translateX(5px);
}

.footer-links i {
    margin-right: 8px;
    width: 20px;
    text-align: center;
}

.contact-info {
    list-style: none;
}

.contact-info li {
    margin-bottom: 10px;
}

.contact-info a {
    color: #fff;
    text-decoration: none;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
}

.contact-info i {
    margin-right: 10px;
    width: 20px;
    text-align: center;
}

.social-links {
    display: flex;
    gap: 15px;
    margin-top: 15px;
}

.social-links a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    background: rgba(255, 255, 255, 0.1);
    border-radius: 50%;
    color: #fff;
    text-decoration: none;
    transition: all 0.3s ease;
}

.social-links a:hover {
    background: #fff;
    color: #e33;
    transform: translateY(-3px);
}

.footer-bottom {
    border-top: 1px solid rgba(255, 255, 255, 0.2);
    padding-top: 20px;
    text-align: center;
    font-size: 14px;
    opacity: 0.8;
}

.footer-nav {
    display: flex;
    justify-content: center;
    gap: 20px;
    margin: 15px 0;
}

.footer-nav a {
    color: #fff;
    text-decoration: none;
    font-weight: 600;
    transition: all 0.3s ease;
}

.footer-nav a:hover {
    color: #ffd700;
    text-decoration: underline;
}

.chat-button {
    position: fixed;
    bottom: 20px;
    right: 20px;
    width: 60px;
    height: 60px;
    background: #25D366;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 24px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
    cursor: pointer;
    z-index: 1000;
    transition: all 0.3s ease;
}

.chat-button:hover {
    transform: scale(1.1);
    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.3);
}

/* Responsive */
@media (max-width: 768px) {
    .footer-columns {
        grid-template-columns: 1fr;
        gap: 25px;
    }
    
    .footer-nav {
        flex-direction: column;
        align-items: center;
        gap: 10px;
    }
    
    .brand-name {
        font-size: 20px;
    }
}

