@import"https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;700&family=Inter:wght@300;400;500;600&display=swap";:root{--color-primary: #1a1a1a;--color-accent: #e6b800;--color-bg: #fff;--color-bg-alt: #f7f7f7;--color-border: #e0e0e0;--color-error: #d7263d;--font-main: "Montserrat", "Helvetica Neue", Arial, sans-serif;--font-size-base: 1rem;--font-size-lg: 1.25rem;--font-size-sm: .95rem;--space-xs: .5rem;--space-sm: 1rem;--space-md: 2rem;--space-lg: 3rem;--radius: 10px}:root{--odd-sox-dark: #1a1a1a;--odd-sox-orange: #FF6B35;--odd-sox-cream: #F5F1E8;--odd-sox-gray: #2d2d2d;--odd-sox-gold: #D4AF37;--font-heading: "Playfair Display", serif;--font-body: "Inter", sans-serif}body{background:var(--odd-sox-cream);font-family:var(--font-body);color:var(--odd-sox-dark);margin:0;min-height:100vh}.page-container{max-width:1200px;margin:0 auto;padding:2rem var(--space-md);min-height:100vh;background:var(--odd-sox-cream)}.page-header{text-align:center;margin-bottom:1.5rem;padding:2rem 0;max-width:1000px;margin-left:auto;margin-right:auto}.brand-header{margin-bottom:1rem;text-align:center}.brand-logo{max-width:300px;height:auto;margin:0 auto;display:block}.brand-main{display:flex;align-items:baseline;justify-content:center;gap:.5rem;margin-bottom:1rem}.brand-prefix{font-size:1.5rem;color:var(--odd-sox-dark);font-weight:400;font-family:var(--font-body)}.brand-name{font-size:6.5rem;color:var(--odd-sox-orange);font-weight:700;font-family:var(--font-heading);font-style:italic;line-height:.8;text-shadow:0 2px 4px rgba(255,107,53,.1)}.brand-suffix{display:block;font-size:1.125rem;color:var(--odd-sox-dark);font-weight:500;font-family:var(--font-body);text-transform:uppercase;letter-spacing:.15em;margin-bottom:1rem}.header-icons{display:flex;justify-content:center;gap:var(--space-lg);margin-bottom:1rem}.header-icon{width:3rem;height:3rem;color:var(--odd-sox-orange);opacity:.8;transition:all .3s ease}.header-icon:hover{opacity:1;transform:scale(1.1)}.page-title{font-family:var(--font-heading);font-size:2.5rem;font-weight:700;margin-bottom:.5rem;line-height:1.2;text-align:center}.title-main{color:var(--odd-sox-dark)}.title-accent{color:var(--odd-sox-orange);margin-left:.25rem}.page-description{font-size:1.25rem;line-height:1.6;color:var(--odd-sox-gray);max-width:900px;margin:0 auto;text-align:center;font-family:var(--font-body)}.form-container{max-width:900px;margin:0 auto;background:#ffffff;border-radius:.75rem;box-shadow:0 4px 32px #00000014;padding:var(--space-lg) var(--space-md);transition:box-shadow .3s;width:100%;box-sizing:border-box;overflow:hidden}.form-container.submitted{text-align:center;padding:var(--space-lg)}.progress-container{margin-bottom:var(--space-lg);padding:0}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-sm);font-size:1.125rem;font-weight:500}.progress-step{color:var(--odd-sox-dark)}.progress-percentage{color:var(--odd-sox-orange);font-weight:600}.progress-bar{width:100%;height:10px;background-color:#e9ecef;border-radius:5px;overflow:hidden;position:relative}.progress-fill{height:100%;background:linear-gradient(90deg,var(--odd-sox-orange) 0%,#ff8a5c 100%);border-radius:5px;transition:width .5s ease-in-out;position:relative}.progress-fill:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.3) 50%,transparent 100%);animation:shimmer 2s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}label{display:block;margin-bottom:.75rem;font-weight:500;font-family:var(--font-body)}label+.radio-grid,label+.radio-group,label+.checkbox-group,label+input,label+textarea,label+.date-row,label+.location-input-container,.location-input-container+label,.radio-grid+label,.radio-group+label,.checkbox-group+label,.info-box+label,.error+label,.error+.location-input-container,.error+.radio-grid,.error+.form-navigation,label+.form-navigation{margin-top:1rem}.section-header+label,.section-header+.info-box,.error+.section-header{margin-top:1rem}input,select,textarea{width:100%;padding:var(--space-xs);border:1px solid #e9ecef;border-radius:.75rem;font-size:var(--font-size-base);margin-top:.75rem;margin-bottom:.75rem;background:#fff;transition:border .2s;font-family:var(--font-body);box-sizing:border-box;max-width:100%}input:focus,select:focus,textarea:focus{border-color:var(--odd-sox-orange);outline:none;box-shadow:0 0 0 2px #ff6b351a}input[type=radio]:focus,input[type=checkbox]:focus{outline:none;box-shadow:none}.helper-text{font-size:var(--font-size-sm);color:#6c757d;margin-top:.75rem;margin-bottom:.75rem}.required{color:#dc3545;margin-left:.2em}.button-row{display:flex;justify-content:flex-end;gap:var(--space-sm);margin-top:2rem}button{background:var(--odd-sox-orange);color:#fff;border:none;border-radius:.75rem;padding:.7em 2em;font-size:var(--font-size-base);font-family:var(--font-body);font-weight:500;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #ff6b3533}button:hover{background:#e55a2b;transform:translateY(-1px);box-shadow:0 4px 12px #ff6b354d}button:disabled{background:#adb5bd;color:#6c757d;cursor:not-allowed;transform:none;box-shadow:none}button.secondary{background:var(--odd-sox-gray);color:#fff}button.secondary:hover{background:#1a1a1a}.error{color:#dc3545;font-size:var(--font-size-sm);margin-top:.75rem;margin-bottom:.75rem}.checkbox-group{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin-top:.75rem;margin-bottom:.75rem}.checkbox-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border:1px solid #e2e8f0;border-radius:.5rem;background-color:#fff;transition:all .2s ease;cursor:pointer;min-width:140px;max-width:100%;box-sizing:border-box}.checkbox-item:hover{border-color:var(--odd-sox-orange);box-shadow:0 2px 4px #0000000d}.checkbox-item input[type=checkbox]{width:1.25rem;height:1.25rem;margin:0;accent-color:var(--odd-sox-orange);cursor:pointer;flex-shrink:0}.checkbox-item label{margin:0;cursor:pointer;font-weight:500;color:var(--odd-sox-dark);flex-grow:1;-webkit-user-select:none;user-select:none}.checkbox-item:has(input[type=checkbox]:checked){border-color:var(--odd-sox-orange);background-color:#ff8c0005}.checkbox-item input[type=checkbox]:focus{outline:2px solid var(--odd-sox-orange);outline-offset:2px}.checkbox-item.date-range{border:none;background-color:transparent;padding:.5rem 0;min-width:auto;margin-top:var(--space-md);margin-bottom:var(--space-md);margin-left:var(--space-md)}.checkbox-item.date-range label{font-size:1.1rem;font-weight:500;display:flex;align-items:center;gap:.5rem;word-wrap:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto}.speaker-icon{width:1.25rem;height:1.25rem;color:var(--odd-sox-orange);flex-shrink:0}.checkbox-item.date-range:hover{border:none;box-shadow:none;background-color:transparent}.checkbox-item.date-range:has(input[type=checkbox]:checked){border:1px solid var(--odd-sox-orange);background-color:#ff8c0005;padding:.75rem 1rem;border-radius:.5rem;min-width:140px;margin-left:0}.radio-group{display:flex;flex-direction:row;gap:2.5em;align-items:center;margin-top:.75rem;margin-bottom:.75rem}.radio-group label{display:flex;align-items:center;font-weight:400;gap:.5em;margin-bottom:0}input[type=radio]{accent-color:var(--odd-sox-orange);margin-right:.5em}.radio-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-sm);margin-top:.75rem;margin-bottom:.75rem}.radio-group .radio-card{flex:1;min-width:0;width:100%;max-width:100%;box-sizing:border-box}.radio-card{position:relative;padding:1rem;border:1px solid #e9ecef;border-radius:.75rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);background-color:#fff;min-height:90px;display:flex;align-items:center;gap:var(--space-sm)}.radio-card:hover{border-color:var(--odd-sox-orange);box-shadow:0 2px 8px #0000000d;transform:translateY(-1px)}.radio-card input[type=radio]{position:static;margin:0;z-index:1;flex-shrink:0;width:1.25rem;height:1.25rem}.radio-card div{position:static;transform:none;width:auto;display:flex;flex-direction:column;justify-content:center;height:auto;flex-grow:1}.radio-card strong{font-weight:600;font-size:var(--font-size-base);line-height:1.3;margin-bottom:.25em;color:var(--odd-sox-dark)}.radio-card span{font-size:var(--font-size-sm);color:#6c757d;line-height:1.3}.radio-card.selected{border-color:var(--odd-sox-orange);box-shadow:0 4px 16px #ff6b351a;background-color:var(--odd-sox-cream)}.radio-card input[type=radio]:checked{accent-color:var(--odd-sox-orange)}.radio-card:has(input[type=radio]:checked){border-color:var(--odd-sox-orange);box-shadow:0 0 0 2px #ff6b3533;background-color:var(--odd-sox-cream)}.radio-card:has(input[type=radio]:checked) input[type=radio]:focus{outline:none;box-shadow:none}.radio-card input[type=radio]:focus{outline:none;box-shadow:none}.info-box{background-color:var(--odd-sox-cream);border:1px solid #e9ecef;border-radius:.75rem;padding:var(--space-md);margin-top:.75rem;margin-bottom:.75rem}.info-box-yellow{text-align:center;margin:0 auto var(--space-lg);max-width:800px}.info-box-yellow p{margin:0;font-size:1.25rem;line-height:1.6;color:var(--odd-sox-gray);font-family:var(--font-body);font-weight:400}.band-info-content{display:flex;align-items:flex-start;gap:var(--space-md)}.band-image{width:120px;height:120px;object-fit:cover;border-radius:.5rem;flex-shrink:0;border:2px solid var(--odd-sox-orange);margin-top:0}.band-description{flex:1;margin-top:0}.band-description p{font-size:1.1rem;line-height:1.7;margin:0;padding:.25rem 0}.band-description p br{display:block;margin-bottom:.75rem}.info-box p{margin:0;line-height:1.6;color:var(--odd-sox-dark);font-family:var(--font-body)}.info-box strong{color:var(--odd-sox-orange);font-weight:600}.date-row{display:flex;align-items:center;gap:var(--space-md);margin-top:.75rem;margin-bottom:.75rem}.date-input{width:200px!important;flex-shrink:0;max-width:100%;box-sizing:border-box}.checkbox-label{display:flex!important;align-items:center;gap:.5em;margin-bottom:0;font-weight:400;cursor:pointer;white-space:nowrap;font-family:var(--font-body)}.checkbox-label input[type=checkbox]{width:auto;margin-bottom:0;accent-color:var(--odd-sox-orange)}.checkbox-label input[type=checkbox]:focus{outline:none;box-shadow:none}.checkbox-group input[type=checkbox]:focus{outline:none;box-shadow:none}.gdpr-section{margin:2rem 0;padding:1.5rem;background-color:#f8f9fa;border-radius:8px;border-left:4px solid var(--odd-sox-orange)}.gdpr-section .checkbox-label{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:1rem;white-space:normal;line-height:1.5}.gdpr-section .checkbox-label:last-child{margin-bottom:0}.gdpr-section .checkbox-label input[type=checkbox]{width:1.25rem;height:1.25rem;margin:0;flex-shrink:0;accent-color:var(--odd-sox-orange);cursor:pointer}.gdpr-section .checkbox-label span{font-size:.95rem;line-height:1.4;flex:1}.gdpr-section .checkbox-label span{font-size:.95rem;line-height:1.4}.gdpr-section .checkbox-label a{color:var(--odd-sox-orange);text-decoration:underline}.gdpr-section .checkbox-label a:hover{text-decoration:none}.section-title{text-align:center;margin-bottom:2rem;font-size:2.5rem;font-weight:700;color:var(--odd-sox-dark);font-family:var(--font-heading);line-height:1.2}.section-subtitle{text-align:center;margin-bottom:var(--space-lg);font-size:1.125rem;color:var(--odd-sox-gray);line-height:1.4;font-family:var(--font-body);font-weight:400}.section-icon{width:4rem;height:4rem;color:var(--odd-sox-orange);margin:0 auto var(--space-md);display:block}.section-header{text-align:center;margin-bottom:var(--space-xl)}.form-navigation{display:flex;justify-content:space-between;align-items:center;margin-top:1.5rem;gap:var(--space-md)}.form-navigation .button{min-width:120px}.submission-success{text-align:center;padding:var(--space-lg)}.submission-success h2{font-family:var(--font-heading);color:var(--odd-sox-dark);margin-bottom:var(--space-md);font-size:2.8rem;font-weight:700}.submission-success p{color:#6c757d;margin-bottom:3rem;font-family:var(--font-body);font-size:1.35rem;line-height:1.7}.submission-success .button{font-size:1.35rem;padding:1.1em 3em;min-width:260px;border-radius:1.2rem;font-weight:600;box-shadow:0 4px 16px #ff6b3521}.success-buttons{display:flex;flex-direction:column;gap:1rem;align-items:center}.success-buttons .button-primary{background:var(--odd-sox-orange)}.success-buttons .button-secondary{background:var(--odd-sox-gray)}@media (max-width: 768px){.page-container{padding:1rem var(--space-sm)}.page-header{margin-bottom:2rem;padding:1rem 0;max-width:100%}.brand-logo{max-width:250px}.brand-main{gap:.4rem;margin-bottom:1.25rem}.brand-name{font-size:4.5rem}.brand-prefix{font-size:1.25rem}.brand-suffix{font-size:1rem;margin-bottom:var(--space-md)}.header-icons{gap:var(--space-md);margin-bottom:var(--space-md)}.header-icon{width:2.5rem;height:2.5rem}.page-title{font-size:2rem}.page-description{font-size:1rem}.form-container{max-width:95%;margin:0 auto;border-radius:.75rem;padding:1.5rem}.section-title{font-size:2.25rem}.section-subtitle{font-size:1.25rem}.section-icon{width:3rem;height:3rem}.radio-grid{grid-template-columns:1fr;gap:var(--space-xs)}.radio-card{min-height:70px;gap:var(--space-xs)}.radio-card input[type=radio]{width:1rem;height:1rem}.date-row{flex-direction:column;align-items:flex-start;gap:var(--space-sm)}.date-input{width:100%!important}}@media (max-width: 600px){.page-container{padding:.5rem var(--space-xs)}.brand-logo{max-width:200px}.brand-main{gap:.3rem;margin-bottom:1rem}.brand-name{font-size:3.5rem}.brand-prefix{font-size:1rem}.brand-suffix{font-size:.875rem;margin-bottom:var(--space-sm)}.header-icons{gap:var(--space-sm)}.header-icon{width:2rem;height:2rem}.page-title{font-size:1.75rem}.page-description{font-size:.95rem}.form-container{max-width:98%;padding:var(--space-sm) var(--space-xs);margin:0 auto}.section-title{font-size:2.5rem}.section-subtitle{font-size:1.5rem}.section-icon{width:3.5rem;height:3.5rem}.radio-group{flex-direction:column;gap:var(--space-sm)}.radio-group .radio-card{min-width:auto;width:100%}.form-navigation{flex-direction:column;gap:var(--space-sm)}.form-navigation .button{width:100%;min-width:auto}.form-navigation .button.primary{order:-1}.form-navigation .button.secondary{order:1}.checkbox-group{flex-direction:column;gap:var(--space-sm)}.checkbox-item{min-width:auto;width:100%;padding:.75rem .5rem}.checkbox-item.date-range{margin-left:0;padding:.5rem 0}.checkbox-item.date-range:has(input[type=checkbox]:checked){margin-left:0;padding:.75rem .5rem}.date-row{flex-direction:column;align-items:flex-start;gap:var(--space-sm)}.date-input{width:100%!important;max-width:100%}.info-box{padding:var(--space-sm)}.band-info-content{flex-direction:column;align-items:center;text-align:center}.band-image{width:100px;height:100px;margin-bottom:var(--space-sm)}.band-description p{text-align:center}textarea[name=dressCode]{min-height:100px;font-size:15px}}@media (max-width: 480px){.brand-main{gap:.25rem;margin-bottom:.75rem}.brand-name{font-size:3rem}.brand-prefix{font-size:.875rem}.brand-suffix{font-size:.75rem;margin-bottom:var(--space-xs)}.header-icons{gap:var(--space-xs)}.header-icon{width:1.75rem;height:1.75rem}.page-title{font-size:1.5rem}.page-description{font-size:.9rem}.form-container{max-width:98%;margin:0 auto;border-radius:.5rem}.section-title{font-size:1.5rem}.section-subtitle{font-size:.8rem}.section-icon{width:2rem;height:2rem}input,select,textarea{font-size:16px}textarea[name=dressCode]{min-height:120px;font-size:14px;line-height:1.4}}.location-input-container{position:relative;width:100%;max-width:100%;box-sizing:border-box}.location-input-container input{width:100%;padding:.75rem 1rem;border:1px solid #e2e8f0;border-radius:.5rem;font-size:1rem;background-color:#fff;color:#1a1a1a;margin-bottom:0}.location-input-container input:focus{border-color:var(--odd-sox-orange);outline:none;box-shadow:0 0 0 2px #ff6b351a}.suggestions-dropdown{position:absolute;top:100%;left:0;right:0;background:white;border:1px solid #e2e8f0;border-radius:.5rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;z-index:10;max-height:300px;overflow-y:auto;margin-top:.25rem}.suggestion-item{padding:.75rem 1rem;cursor:pointer;border-bottom:1px solid #f1f5f9;transition:background-color .2s ease}.suggestion-item:last-child{border-bottom:none}.suggestion-item:hover{background-color:#f8fafc}.suggestion-title{font-weight:600;color:var(--odd-sox-dark);margin-bottom:.25rem;font-size:.95rem}.suggestion-address{color:#6b7280;font-size:.875rem;line-height:1.4}.info-box .band-info-content{display:flex;align-items:flex-start;gap:var(--space-md)}.info-box .band-image{width:120px;height:120px;object-fit:cover;border-radius:.5rem;flex-shrink:0;border:2px solid var(--odd-sox-orange);margin-top:0}.info-box .band-description{flex:1;margin-top:0}.info-box .band-description p{font-size:1.1rem;line-height:1.7;margin:0;padding:.25rem 0}@media (max-width: 768px){.info-box .band-info-content{flex-direction:column!important;align-items:center!important;text-align:center!important}.info-box .band-image{width:140px!important;height:140px!important;margin-bottom:var(--space-sm)!important;margin-right:0!important}.info-box .band-description p{text-align:center!important}textarea[name=dressCode]{min-height:100px;font-size:15px}.section-header .section-title{font-size:2.1rem!important}.section-header .section-subtitle{font-size:1.3rem!important}.section-header .section-icon{width:3.5rem!important;height:3.5rem!important}}@media (max-width: 480px){.info-box .band-info-content{flex-direction:column!important;align-items:center!important;text-align:center!important}.info-box .band-image{width:160px!important;height:160px!important;margin-bottom:var(--space-sm)!important;margin-right:0!important}.info-box .band-description p{text-align:center!important}textarea[name=dressCode]{min-height:120px;font-size:14px;line-height:1.4}.section-header .section-title{font-size:2.3rem!important}.section-header .section-subtitle{font-size:1.4rem!important}.section-header .section-icon{width:4rem!important;height:4rem!important}}.radio-group.concert-duration{display:flex;justify-content:center;gap:2rem;margin-bottom:2rem}.radio-group.concert-duration .radio-card{min-width:200px;text-align:left}.info-icon{display:inline-block;margin-right:.5rem;color:var(--odd-sox-orange);vertical-align:middle}.radio-group.extra-sets+p{margin-bottom:2rem;font-size:1rem;line-height:1.5}label:has(+textarea[name=dressCode]){margin-bottom:.25rem}textarea[name=dressCode]{margin-top:.25rem}label:has(+input[type=date]),label:has(+.date-row),label:has(+.date-input){margin-bottom:.25rem}label+.date-row{margin-top:.25rem}input[type=date],.date-input{margin-top:.25rem}.radio-group.extra-sets{display:flex;justify-content:center;gap:2rem;margin-bottom:1rem}.radio-group.extra-sets .radio-card.extra-set-option{min-width:180px;text-align:left;padding:.75rem 1rem}
