@tailwind base;@tailwind components;@tailwind utilities;:root{--primary: #800020;--primary-light: #9d1b32;--secondary: #d4af37;--secondary-light: #f3e5ab;--background: #fdfbf7;--text-primary: #2d1b20;--text-secondary: #5e4b50;--text-tertiary: #8b7e82;--error: #ef4444;--success: #10b981}body{margin:0;font-family:Inter,system-ui,-apple-system,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--background);color:var(--text-primary)}.container{max-width:800px;margin:0 auto;padding:2rem}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.registro-header{text-align:center;margin-bottom:2rem;padding:2rem;background:#fff;border-radius:1rem;box-shadow:0 4px 6px -1px #0000001a;border-bottom:4px solid var(--primary);display:flex;justify-content:center}.header-content{display:flex;align-items:center;gap:1.5rem;max-width:800px;width:100%;position:relative}.logo-container{width:80px;height:80px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.logo-wrapper{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.logo-image{max-width:100%;max-height:100%;object-fit:contain}.header-text{text-align:left;flex-grow:1}.header-title{color:var(--primary);font-size:2rem;font-weight:800;margin:0;line-height:1.2}.header-subtitle{color:var(--text-secondary);margin:.5rem 0 0;font-size:1rem}.info-button{background:none;border:none;font-size:1.5rem;cursor:pointer;padding:.5rem;border-radius:50%;transition:transform .2s}.info-button:hover{transform:scale(1.1);background-color:var(--secondary-light)}.registro-container{animation:fadeIn .5s ease-out}.registro-form{display:flex;flex-direction:column;gap:2rem}.form-section{background:#fff;padding:2rem;border-radius:1rem;box-shadow:0 4px 6px -1px #0000000d;border:1px solid rgba(0,0,0,.05);transition:transform .2s,box-shadow .2s}.form-section:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a}.section-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;border-bottom:2px solid var(--secondary-light);padding-bottom:1rem}.section-icon{font-size:1.5rem;background:var(--secondary-light);padding:.5rem;border-radius:50%}.section-title{color:var(--primary);font-size:1.25rem;font-weight:600;margin:0}.form-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}.address-grid{display:grid;grid-template-columns:1fr;gap:1rem;margin-bottom:1rem}.location-grid{display:grid;grid-template-columns:1fr;gap:1rem}@media (min-width: 640px){.form-grid{grid-template-columns:1fr 1fr}.address-grid{grid-template-columns:2fr 1fr}.location-grid{grid-template-columns:1fr 1fr}}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-label{display:flex;align-items:center;gap:.5rem;font-weight:500;color:var(--text-secondary);font-size:.95rem}.label-icon{opacity:.7}.form-label.required:after{content:"*";color:var(--error);margin-left:.25rem}.form-input,.form-select{padding:.75rem 1rem;border:2px solid #e5e7eb;border-radius:.75rem;font-size:1rem;transition:all .2s;background-color:#f9fafb;width:100%;box-sizing:border-box}.form-input:focus,.form-select:focus{outline:none;border-color:var(--primary);background-color:#fff;box-shadow:0 0 0 4px #8000201a}.input-error{border-color:var(--error);background-color:#fef2f2}.form-error{color:var(--error);font-size:.875rem;margin-top:.25rem;display:flex;align-items:center;gap:.25rem}.form-error:before{content:"⚠️";font-size:.8rem}.submit-button{background:var(--primary);color:#fff;border:none;padding:1rem 2rem;font-size:1.1rem;font-weight:600;border-radius:.75rem;cursor:pointer;transition:all .2s;width:100%;box-shadow:0 4px 6px -1px #8000204d}.submit-button:hover:not(:disabled){background:var(--primary-light);transform:translateY(-2px);box-shadow:0 10px 15px -3px #80002066}.submit-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.alert{padding:1rem;border-radius:.75rem;margin-bottom:1.5rem;display:flex;align-items:center;gap:.5rem}.alert-error{background-color:#fef2f2;color:var(--error);border:1px solid #fee2e2}.alert-success{background-color:#ecfdf5;color:var(--success);border:1px solid #d1fae5}.cupos-card{background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;padding:1.5rem;border-radius:1rem;margin-bottom:2rem;box-shadow:0 10px 15px -3px #8000204d}.cupos-title{margin:0 0 1rem;font-size:1.25rem;display:flex;align-items:center;gap:.5rem}.cupos-summary{background:#ffffff1a;padding:1rem;border-radius:.5rem;margin-bottom:1rem}.cupos-total{display:flex;align-items:baseline;gap:.5rem}.cupos-number{font-size:2rem;font-weight:800}.cupos-label{opacity:.9}.cupos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.75rem}.cupo-item{background:#fff;padding:.75rem;border-radius:.5rem;color:var(--text-primary);text-align:center;transition:transform .2s}.cupo-item.cupo-disponible{border-left:4px solid var(--success)}.cupo-item.cupo-lleno{border-left:4px solid var(--error);opacity:.8;background:#f3f4f6}.cupo-horario{font-weight:700;font-size:1.1rem;margin-bottom:.25rem}.cupo-badge{font-size:.8rem;padding:.25rem .5rem;border-radius:1rem;display:inline-block}.cupo-badge.disponible{background-color:#d1fae5;color:#065f46}.cupo-badge.lleno{background-color:#fee2e2;color:#991b1b}.success-page-wrapper{display:flex;justify-content:center;align-items:center;min-height:80vh;padding:2rem;animation:fadeIn .8s ease-out}.success-card{background:#fff;padding:3rem 2rem;border-radius:1.5rem;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;text-align:center;max-width:500px;width:100%;border-top:6px solid var(--success)}.success-icon-wrapper{background:#d1fae5;width:100px;height:100px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 2rem;box-shadow:0 0 0 10px #ecfdf5}.success-checkmark{font-size:4rem;animation:slideIn .5s cubic-bezier(.68,-.55,.265,1.55)}.success-title{color:var(--primary);font-size:2rem;margin-bottom:1rem}.success-message{color:var(--text-secondary);font-size:1.1rem;margin-bottom:2rem}.redirect-bar-container{height:6px;background:#f3f4f6;border-radius:3px;overflow:hidden;margin:2rem 0 1rem}.redirect-bar{height:100%;background:var(--secondary);width:0%;animation:fillBar 3s linear forwards}@keyframes fillBar{to{width:100%}}.redirect-text{color:var(--text-tertiary);font-size:.9rem;font-style:italic}.boleto-container{display:flex;justify-content:center;padding:2rem;animation:fadeIn .5s ease-out}.boleto-card{background:#fff;width:100%;max-width:400px;border-radius:1rem;overflow:hidden;box-shadow:0 10px 15px -3px #0000001a;position:relative}.boleto-card:before,.boleto-card:after{content:"";position:absolute;top:65%;width:40px;height:40px;background-color:var(--background);border-radius:50%;z-index:10}.boleto-card:before{left:-20px}.boleto-card:after{right:-20px}.boleto-header{background:var(--primary);padding:1.5rem;text-align:center;color:#fff;border-bottom:4px dashed rgba(255,255,255,.3)}.boleto-title{margin:0;font-size:1.5rem;font-weight:800;text-transform:uppercase;letter-spacing:1px}.boleto-felicidades{margin:.5rem 0 0;font-size:.95rem;font-weight:500;opacity:.95;font-style:italic}.boleto-subtitle{margin:.5rem 0 0;opacity:.9;font-size:.9rem}.boleto-body{padding:2rem;text-align:center}.boleto-folio{margin-bottom:1.5rem}.boleto-folio-label{font-size:.85rem;color:var(--text-secondary);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px}.boleto-folio-value{font-size:1.25rem;font-weight:700;color:var(--primary);font-family:monospace;letter-spacing:1px}.boleto-qr-section{margin:1.5rem 0;display:flex;justify-content:center;align-items:center}.qr-wrapper{background:#fff;padding:1rem;border:2px solid var(--secondary);border-radius:1rem;display:inline-block;margin-bottom:1.5rem}.boleto-info{text-align:left;display:flex;flex-direction:column;gap:1rem}.boleto-info-grid{display:flex;flex-direction:column;gap:1rem;text-align:left}.boleto-info-item{display:flex;flex-direction:row;align-items:baseline;gap:.5rem}.boleto-label{color:var(--text-secondary);font-size:.9rem;font-weight:500;white-space:nowrap}.boleto-value{font-weight:600;color:var(--text-primary);font-size:1rem;flex:1}.info-row{display:flex;justify-content:space-between;border-bottom:1px solid #f3f4f6;padding-bottom:.5rem}.info-label{color:var(--text-tertiary);font-size:.9rem}.info-value{font-weight:600;color:var(--text-primary)}.boleto-footer{background:#f9fafb;padding:1rem;text-align:center;border-top:2px dashed #e5e7eb}.footer-note{font-size:.8rem;color:var(--text-tertiary);margin-bottom:.5rem}@media print{.no-print{display:none!important}.boleto-container{background:#fff;padding:0;display:block}.boleto-card{box-shadow:none;border:1px solid #ccc;max-width:100%;width:100%}.boleto-card:before,.boleto-card:after{display:none}}.suggestions-list{position:absolute;top:100%;left:0;right:0;background-color:#fff;border:1px solid #d1d5db;border-radius:.5rem;box-shadow:0 4px 6px -1px #0000001a;max-height:200px;overflow-y:auto;z-index:1000;margin-top:.25rem;padding:0;list-style:none}.suggestion-item{padding:.75rem 1rem;cursor:pointer;transition:background-color .2s;color:#374151}.suggestion-item:hover{background-color:#f3f4f6;color:#1f2937}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:2000;animation:fadeIn .2s ease-out;padding:1rem}.modal-content{background:#fff;padding:0;border-radius:1rem;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;position:relative;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{padding:1.5rem;border-bottom:1px solid #f3f4f6;display:flex;align-items:center;gap:1rem;position:sticky;top:0;background:#fff;z-index:10}.modal-icon{font-size:1.5rem;background:#f3f4f6;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center}.modal-title{margin:0;font-size:1.25rem;flex-grow:1;color:var(--primary)}.modal-close{background:none;border:none;font-size:2rem;line-height:1;color:#9ca3af;cursor:pointer;padding:.5rem;border-radius:.5rem;transition:all .2s}.modal-close:hover{background-color:#f3f4f6;color:#4b5563}.modal-body{padding:1.5rem;color:var(--text-secondary)}.modal-info .modal-icon{background-color:#e0f2fe}.modal-success .modal-icon{background-color:#dcfce7}.modal-warning .modal-icon{background-color:#fef9c3}.modal-error .modal-icon{background-color:#fee2e2}@media (max-width: 640px){.container{padding:1rem}.registro-header{padding:1.5rem 1rem;flex-direction:column;text-align:center;gap:1rem}.header-content{flex-direction:column;text-align:center;gap:1rem;position:relative}.header-text{text-align:center;width:100%}.header-title{font-size:1.5rem}.header-subtitle{font-size:.9rem;padding:0 .5rem}.form-section{padding:1.25rem}.cupos-grid{grid-template-columns:repeat(2,1fr);gap:.5rem}.cupo-horario{font-size:.9rem}.cupo-item{padding:.5rem}.cupo-number{font-size:1.5rem}.info-button{position:absolute;top:0;right:0;transform:none}.success-card{padding:2rem 1.5rem}.success-title{font-size:1.5rem}.modal-content{margin:1rem;width:calc(100% - 2rem);max-height:80vh}}@media (max-width: 360px){.header-title{font-size:1.25rem}.cupos-grid{grid-template-columns:1fr}.logo-container{width:60px;height:60px}.form-section{padding:1rem}}.dashboard-grid{display:grid;grid-template-columns:1fr;gap:1.5rem;width:100%;min-width:0}@media (min-width: 1024px){.dashboard-grid{grid-template-columns:320px minmax(0,1fr);align-items:start}.dashboard-grid .dashboard-operacion-panel{min-width:0;overflow:hidden}}.dashboard-card{background:#fff;border-radius:1rem;padding:1.5rem;box-shadow:0 4px 6px -1px #0000001a;border:1px solid rgba(0,0,0,.05)}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid #f3f4f6}.stat-card{background:#f8fafc;padding:1rem;border-radius:.75rem;border-left:4px solid var(--primary)}.stat-label{color:var(--text-tertiary);font-size:.875rem;margin-bottom:.25rem}.stat-value{color:var(--text-primary);font-size:1.5rem;font-weight:700}.table-container{overflow-x:auto;border-radius:.75rem;border:1px solid #e5e7eb;max-width:100%;-webkit-overflow-scrolling:touch}.data-table{width:100%;min-width:580px;border-collapse:collapse;font-size:.875rem}.data-table td{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:220px;padding:.75rem .5rem;border-bottom:1px solid #e5e7eb;color:var(--text-primary)}.data-table th{background:#f9fafb;padding:.75rem .5rem;text-align:left;font-size:.875rem;font-weight:600;color:var(--text-secondary);border-bottom:1px solid #e5e7eb}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover{background-color:#f8fafc}.status-badge{padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;display:inline-flex;align-items:center;gap:.25rem}.status-registrado{background-color:#fef3c7;color:#92400e}.status-atendido{background-color:#dcfce7;color:#166534}.status-cancelado{background-color:#fee2e2;color:#991b1b}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:.5rem;font-weight:600;cursor:pointer;transition:all .2s;border:none;font-size:.95rem}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-light);transform:translateY(-1px)}.btn-secondary{background:#fff;border:2px solid var(--primary);color:var(--primary)}.btn-secondary:hover:not(:disabled){background:#fff5f5}.btn-danger{background:#fee2e2;color:#991b1b}.btn-danger:hover{background:#fecaca}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}
