@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&family=Playfair+Display:ital,wght@0,500;0,700;1,400&display=swap";:root{--primary:#d95d00;--primary-hover:#b84f00;--secondary:#b8912d;--accent:#ff8c1a;--bg-light:#fdfaf6;--card-bg:#fff;--text-dark:#2d3748;--text-muted:#718096;--border-color:#d95d0026;--success:#2f855a;--danger:#c53030;--font-sans:"Outfit", sans-serif;--font-serif:"Playfair Display", serif}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background-color:var(--bg-light);color:var(--text-dark);background-image:radial-gradient(#d95d0008 1px,#0000 0),radial-gradient(#d95d0008 1px,#0000 0);background-position:0 0,12px 12px;background-size:24px 24px;min-height:100vh}.devotee-header{z-index:1000;background:linear-gradient(135deg, var(--primary), var(--secondary));color:#fff;text-align:center;width:100%;padding:15px 20px;position:fixed;top:0;left:0;box-shadow:0 4px 15px #d95d0033}.devotee-title{font-family:var(--font-serif);letter-spacing:.5px;text-shadow:0 2px 4px #0003;font-size:2.2rem;font-weight:700}.devotee-subtitle{opacity:.9;letter-spacing:1px;text-transform:uppercase;margin-top:5px;font-size:1rem;font-weight:300}.container{width:100%;max-width:800px;margin:25px auto 50px;padding:0 20px}.step-progress{justify-content:space-between;align-items:center;margin-bottom:35px;padding:0 10px;display:flex;position:relative}.step-progress:before{content:"";z-index:1;background:#e2e8f0;width:100%;height:2px;position:absolute;top:50%;left:0;transform:translateY(-50%)}.step-node{width:36px;height:36px;color:var(--text-muted);z-index:2;background:#edf2f7;border:2px solid #e2e8f0;border-radius:50%;justify-content:center;align-items:center;font-size:.9rem;font-weight:600;transition:all .3s;display:flex;position:relative}.step-node.active{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 0 0 4px #d95d0033}.step-node.completed{background:var(--secondary);border-color:var(--secondary);color:#fff}.wizard-card{background:var(--card-bg);border:1px solid #d95d001a;border-radius:16px;padding:40px;animation:.5s ease-out slideUp;box-shadow:0 10px 25px #d95d000d}.wizard-title{font-family:var(--font-serif);color:var(--primary);border-bottom:2px solid #d95d000d;margin-bottom:25px;padding-bottom:12px;font-size:1.6rem}.form-group{margin-bottom:22px}.form-label{text-transform:uppercase;color:var(--secondary);letter-spacing:1px;margin-bottom:8px;font-size:.85rem;font-weight:600;display:block}.form-control{width:100%;font-family:var(--font-sans);color:var(--text-dark);background-color:#fff;border:1.5px solid #e2e8f0;border-radius:8px;padding:12px 16px;font-size:1rem;transition:all .3s}.form-control:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #d95d0026}.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23d95d00' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;background-size:16px;padding-right:40px}.wizard-footer{border-top:1px solid #0000000d;justify-content:space-between;margin-top:35px;padding-top:25px;display:flex}.btn{font-family:var(--font-sans);cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;padding:12px 28px;font-size:1rem;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1);display:inline-flex}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 4px 10px #d95d0033}.btn-primary:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{color:var(--text-dark);background:#edf2f7}.btn-secondary:hover{background:#e2e8f0}.slots-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:15px;margin-top:15px;display:grid}.slot-card{cursor:pointer;background:#fff;border:2.5px solid #edf2f7;border-radius:12px;padding:16px;transition:all .3s;position:relative}.slot-card:hover:not(.disabled){border-color:var(--primary);transform:translateY(-2px);box-shadow:0 5px 12px #d95d000d}.slot-card.selected{border-color:var(--primary);background:#d95d0008}.slot-card.disabled{opacity:.5;cursor:not-allowed;background:#f7fafc}.slot-time{color:var(--text-dark);font-size:1.1rem;font-weight:700}.slot-capacity{color:var(--text-muted);margin-top:5px;font-size:.8rem}.camera-container{flex-direction:column;align-items:center;gap:15px;margin-top:10px;display:flex}.camera-viewport{border:3px solid var(--secondary);background:#1a202c;border-radius:12px;width:320px;height:240px;position:relative;overflow:hidden}.camera-stream,.captured-image{object-fit:cover;width:100%;height:100%}.fallback-upload{text-align:center;cursor:pointer;background:#d95d0003;border:2px dashed #d95d004d;border-radius:12px;width:100%;padding:25px;transition:all .3s}.fallback-upload:hover{border-color:var(--primary);background:#d95d0008}.review-table{border-collapse:collapse;width:100%;margin-bottom:25px}.review-table tr{border-bottom:1px solid #edf2f7}.review-table td{padding:12px 0;font-size:.95rem}.review-label{color:var(--secondary);width:35%;font-weight:600}.review-value{color:var(--text-dark)}.ticket-container{border:2px solid var(--secondary);background:#fff radial-gradient(#d95d0003 15%,#0000 15%) 0 0/10px 10px;border-radius:15px;max-width:500px;margin:0 auto;padding:30px;position:relative;box-shadow:0 10px 30px #0000001a}.ticket-header{text-align:center;border-bottom:2px dashed var(--secondary);margin-bottom:20px;padding-bottom:20px}.ticket-temple-name{font-family:var(--font-serif);color:var(--primary);font-size:1.5rem;font-weight:700}.ticket-tagline{letter-spacing:1px;text-transform:uppercase;color:var(--text-muted);margin-top:3px;font-size:.8rem}.ticket-body{gap:20px;display:flex}.ticket-photo{border:2px solid var(--secondary);border-radius:8px;flex-shrink:0;width:110px;height:130px;overflow:hidden}.ticket-photo img{object-fit:cover;width:100%;height:100%}.ticket-details{flex-direction:column;flex-grow:1;gap:8px;font-size:.9rem;display:flex}.ticket-detail-item strong{color:var(--secondary)}.ticket-footer{border-top:2px dashed var(--secondary);text-align:center;margin-top:25px;padding-top:20px}.ticket-number{color:var(--primary);background:#d95d000d;border-radius:5px;margin-bottom:15px;padding:5px 15px;font-family:monospace;font-size:1.2rem;font-weight:700;display:inline-block}.simulated-barcode{background:repeating-linear-gradient(90deg,#000,#000 2px,#fff 2px 6px);width:80%;height:50px;margin:0 auto}.print-btn-container{text-align:center;margin-top:25px}.error-message{border:1px solid var(--danger);color:var(--danger);background:#c530301a;border-radius:8px;margin-bottom:20px;padding:12px 16px;font-weight:500}@keyframes slideUp{0%{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}@media print{*{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}body{background:0 0}.devotee-header,.step-progress,.wizard-footer,.print-btn-container{display:none!important}.wizard-card{box-shadow:none;border:none;padding:0}.ticket-container{box-shadow:none;border:2px solid #000;page-break-after:always!important;break-after:page!important;page-break-inside:avoid!important;break-inside:avoid!important;margin-top:0!important;margin-bottom:20px!important}.ticket-container:last-of-type{page-break-after:avoid!important;break-after:avoid!important;margin-bottom:0!important}}.devotee-card{border:1px solid var(--border-color);background:#fff;border-radius:12px;margin-bottom:20px;padding:20px;animation:.3s ease-out slideUp;position:relative;box-shadow:0 4px 10px #00000005}.devotee-card-header{border-bottom:1px dashed var(--border-color);justify-content:space-between;align-items:center;margin-bottom:15px;padding-bottom:8px;display:flex}.devotee-card-title{color:var(--primary);font-size:1.05rem;font-weight:600}.btn-remove-devotee{color:var(--danger);border:1.5px solid var(--danger);cursor:pointer;background:0 0;border-radius:6px;padding:5px 12px;font-size:.8rem;font-weight:600;transition:all .2s}.btn-remove-devotee:hover{background:var(--danger);color:#fff}.btn-add-devotee{border:2.5px dashed var(--primary);width:100%;color:var(--primary);cursor:pointer;background:#d95d0003;border-radius:10px;justify-content:center;align-items:center;gap:8px;margin-top:10px;margin-bottom:25px;padding:14px;font-size:.95rem;font-weight:600;transition:all .3s;display:flex}.btn-add-devotee:hover:not(:disabled){border-color:var(--primary-hover);color:var(--primary-hover);background:#d95d000a}.btn-add-devotee:disabled{opacity:.5;cursor:not-allowed;border-color:var(--text-muted);color:var(--text-muted);background:#edf2f7}.devotee-id-card{border:1px solid var(--border-color);background:#fff;border-radius:12px;margin-bottom:20px;padding:20px;box-shadow:0 4px 10px #00000005}.devotee-id-title{color:var(--secondary);border-bottom:1px dashed var(--border-color);margin-bottom:15px;padding-bottom:8px;font-size:1.05rem;font-weight:600}.btn-logout-devotee{color:#fff;font-family:var(--font-sans);cursor:pointer;background:#ffffff26;border:1.5px solid #ffffff59;border-radius:6px;padding:8px 18px;font-size:.9rem;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1);position:absolute;top:50%;right:25px;transform:translateY(-50%)}.btn-logout-devotee:hover{background:#ffffff4d;border-color:#fff;box-shadow:0 4px 10px #0000001a}@media (width<=768px){.devotee-header{padding-bottom:70px}.btn-logout-devotee{top:auto;bottom:15px;right:50%;transform:translate(50%)}.portal-nav{margin-top:150px}.container{margin-top:20px}}.portal-nav{z-index:10;justify-content:center;gap:15px;margin-top:110px;display:flex;position:relative}.nav-tab{border:1.5px solid var(--border-color);color:var(--text-dark);font-family:var(--font-sans);cursor:pointer;background:#fff;border-radius:30px;align-items:center;gap:8px;padding:10px 24px;font-size:.95rem;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1);display:inline-flex;box-shadow:0 4px 10px #00000005}.nav-tab:hover{border-color:var(--primary);color:var(--primary);transform:translateY(-1px)}.nav-tab.active{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 4px 12px #d95d0040}.login-card{max-width:450px;margin:0 auto}.btn-block{width:100%}.status-badge{justify-content:center;align-items:center;display:inline-flex}.status-upcoming{color:#10b981;background-color:#10b9811a;border:1.5px solid #10b98133}.status-completed{color:var(--text-muted);background-color:#7180961a;border:1.5px solid #71809640}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:2000;background:#000000a6;justify-content:center;align-items:center;width:100%;height:100%;animation:.25s ease-out fadeIn;display:flex;position:fixed;top:0;left:0}.modal-content{border:1px solid var(--border-color);background:#fff;animation:.3s cubic-bezier(.34,1.56,.64,1) scaleIn;position:relative;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.modal-header{justify-content:space-between;align-items:center;display:flex}.modal-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;transition:color .2s}.modal-close:hover{color:var(--danger)}body.modal-open{overflow:hidden}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@media print{body.modal-open{overflow:visible}body.modal-open .devotee-header,body.modal-open .portal-nav,body.modal-open .container>:not(.modal-overlay){display:none!important}body.modal-open .container{width:100%!important;max-width:100%!important;margin:0!important;padding:0!important}body.modal-open .modal-overlay{-webkit-backdrop-filter:none!important;backdrop-filter:none!important;z-index:auto!important;background:0 0!important;width:100%!important;height:auto!important;padding:0!important;display:block!important;position:static!important}body.modal-open .modal-content{box-shadow:none!important;background:0 0!important;border:none!important;width:100%!important;max-width:100%!important;height:auto!important;padding:0!important;overflow:visible!important}body.modal-open .booking-detail-body{height:auto!important;max-height:none!important;overflow:visible!important}body.modal-open .modal-tickets-list{display:block!important}body.modal-open .modal-close,body.modal-open .modal-footer,body.modal-open .modal-header{display:none!important}body.modal-open .modal-tickets-list>div{page-break-inside:avoid!important;break-inside:avoid!important;background:#fff!important;border:2px solid #000!important;margin-bottom:20px!important;padding:20px!important}body.modal-open .modal-tickets-list>div:last-of-type{margin-bottom:0!important}}
