.topbar{position:sticky;top:0;z-index:1000;background:linear-gradient(180deg,#2a2a2a,#1a1a1a);border-bottom:3px solid #4a5c3a;box-shadow:0 4px 12px #0009}.topbar-container{max-width:1400px;margin:0 auto;padding:1rem 0rem;display:flex;justify-content:space-between;align-items:center;gap:1rem}.topbar-logo-section{display:flex;align-items:center;gap:1rem;flex-shrink:0}.topbar-logo{height:50px;width:auto;filter:drop-shadow(2px 2px 4px rgba(0,0,0,.5))}.topbar-title{font-family:Impact,Franklin Gothic Bold,Arial,sans-serif;font-size:1.2rem;font-weight:900;color:#d4c5a0;text-transform:uppercase;letter-spacing:1px;text-shadow:2px 2px 4px rgba(0,0,0,.8);display:none}.topbar-nav{display:flex;gap:.5rem;align-items:center}.nav-link{background:#3a3a3a;border:2px solid #5a6a4a;color:#e0d5b0;padding:.75rem 1.5rem;font-family:Arial Black,Arial Bold,sans-serif;font-size:.95rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;transition:all .2s ease;position:relative;clip-path:polygon(5% 0%,100% 0%,95% 100%,0% 100%);box-shadow:2px 2px #0006}.nav-link:hover{background:#4a5c3a;color:#fff;transform:translate(-1px,-1px);box-shadow:3px 3px #0009}.nav-link:active{transform:translate(1px,1px);box-shadow:1px 1px #0006}.nav-link.tickets{background:#5a6a4a;border-color:#d4c5a0;color:#fff}.nav-link.tickets:hover{background:#6a7a5a;border-color:#e0d5b0}.mobile-menu-toggle{display:none;flex-direction:column;gap:4px;background:none;border:none;cursor:pointer;padding:.5rem}.mobile-menu-toggle span{width:28px;height:3px;background:#d4c5a0;transition:all .3s ease;box-shadow:1px 1px 2px #00000080}@media (max-width: 1024px){.topbar-title{font-size:1rem}.nav-link{padding:.6rem 1rem;font-size:.85rem}}@media (max-width: 768px){.topbar-container{padding:.75rem 1rem}.topbar-title{display:none}.mobile-menu-toggle{display:flex}.topbar-nav{position:absolute;top:100%;left:0;right:0;background:#1a1a1a;flex-direction:column;gap:0;border-bottom:3px solid #4a5c3a;box-shadow:0 4px 12px #0009;max-height:0;overflow:hidden;transition:max-height .3s ease}.topbar-nav.mobile-open{max-height:400px}.nav-link{width:100%;clip-path:none;border-left:none;border-right:none;border-top:none;text-align:left}}@media (min-width: 769px){.topbar-title{display:block}}.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden;background:linear-gradient(180deg,#3a4a2a,#2a3a1a,#1a2a1a)}.hero-background{position:absolute;top:0;left:0;right:0;bottom:0;background-image:url(/assets/img/epafestival.co.nz.png);background-size:cover;background-position:center;opacity:.3;filter:contrast(1.2) brightness(.8)}.hero-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:repeating-linear-gradient(0deg,rgba(0,0,0,.05) 0px,transparent 1px,transparent 2px,rgba(0,0,0,.05) 3px),radial-gradient(circle at 50% 50%,transparent 0%,rgba(0,0,0,.4) 100%);opacity:.6;mix-blend-mode:multiply}.hero-content{position:relative;z-index:10;text-align:center;padding:2rem;max-width:1000px}.hero-title{font-family:Impact,Franklin Gothic Bold,Arial,sans-serif;font-size:clamp(2.5rem,8vw,5rem);font-weight:900;color:#e0d5b0;text-transform:uppercase;letter-spacing:3px;margin:0 0 1rem;text-shadow:3px 3px 0 #1a1a1a,4px 4px 8px rgba(0,0,0,.8),-1px -1px 0 #2a2a2a;line-height:1.1;animation:fadeInUp 1s ease-out}.hero-tagline{font-family:Arial Black,Arial Bold,sans-serif;font-size:clamp(1.2rem,3vw,2rem);color:#b8d4a0;text-transform:uppercase;letter-spacing:2px;margin:0 0 1rem;text-shadow:2px 2px 4px rgba(0,0,0,.9),0 0 20px rgba(74,92,58,.5);animation:fadeInUp 1s ease-out .2s backwards}.hero-subtitle{font-family:Arial,sans-serif;font-size:clamp(1rem,2vw,1.3rem);color:#d4c5a0;margin:0 0 3rem;font-weight:400;text-shadow:2px 2px 4px rgba(0,0,0,.9);animation:fadeInUp 1s ease-out .4s backwards}.hero-cta{display:flex;gap:1.5rem;justify-content:center;flex-wrap:wrap;animation:fadeInUp 1s ease-out .6s backwards}.cta-button{font-family:Arial Black,Arial Bold,sans-serif;font-size:1.1rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;padding:1rem 2.5rem;border:3px solid;cursor:pointer;transition:all .3s ease;clip-path:polygon(5% 0%,100% 0%,95% 100%,0% 100%);box-shadow:4px 4px #00000080;position:relative}.cta-button.primary{background:#5a6a4a;border-color:#d4c5a0;color:#fff}.cta-button.primary:hover{background:#6a7a5a;transform:translate(-2px,-2px);box-shadow:6px 6px #0009}.cta-button.secondary{background:transparent;border-color:#b8d4a0;color:#b8d4a0}.cta-button.secondary:hover{background:#b8d4a01a;border-color:#d4c5a0;color:#d4c5a0;transform:translate(-2px,-2px);box-shadow:6px 6px #0009}.cta-button:active{transform:translate(2px,2px);box-shadow:2px 2px #00000080}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.hero{min-height:80vh}.hero-content{padding:1.5rem}.hero-cta{gap:1rem}.cta-button{font-size:1rem;padding:.875rem 2rem}}.festival-overview{padding:5rem 2rem;background:linear-gradient(180deg,#2a3a1a,#1a2a1a);position:relative}.festival-overview:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,#5a6a4a,transparent)}.overview-container{max-width:1200px;margin:0 auto}.section-title{font-family:Impact,Franklin Gothic Bold,Arial,sans-serif;font-size:clamp(2rem,5vw,3.5rem);color:#d4c5a0;text-transform:uppercase;letter-spacing:2px;text-align:center;margin:0 0 3rem;text-shadow:2px 2px 0 #1a1a1a,3px 3px 8px rgba(0,0,0,.8)}.overview-content{display:flex;flex-direction:column;gap:3rem}.intro-text{font-family:Arial,sans-serif;font-size:clamp(1.1rem,2vw,1.4rem);color:#b8d4a0;text-align:center;line-height:1.8;margin:0 0 2rem;max-width:800px;margin-left:auto;margin-right:auto;font-weight:400}.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem}.feature-card{background:#2a2a2a;border:2px solid #4a5c3a;padding:2rem;position:relative;box-shadow:4px 4px #0006;transition:all .3s ease;clip-path:polygon(0 0,98% 0,100% 8%,100% 100%,2% 100%,0 92%)}.feature-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#5a6a4a,transparent)}.feature-card:hover{transform:translate(-3px,-3px);box-shadow:7px 7px #0009;border-color:#6a7a5a}.feature-title{font-family:Arial Black,Arial Bold,sans-serif;font-size:1.4rem;color:#e0d5b0;text-transform:uppercase;letter-spacing:1px;margin:0 0 1rem;text-shadow:2px 2px 4px rgba(0,0,0,.8)}.feature-description{font-family:Arial,sans-serif;font-size:1rem;color:silver;line-height:1.7;margin:0}@media (max-width: 768px){.festival-overview{padding:3rem 1.5rem}.feature-grid{grid-template-columns:1fr;gap:1.5rem}.feature-card{padding:1.5rem}}.bazaar-section{padding:5rem 2rem;background:linear-gradient(180deg,#1a2a1a,#2a2a1a,#1a1a1a);position:relative}.bazaar-section:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,#4a5c3a,#5a6a4a,#4a5c3a,transparent)}.bazaar-container{max-width:1400px;margin:0 auto}.bazaar-intro{font-family:Arial,sans-serif;font-size:clamp(1.1rem,2vw,1.3rem);color:#b8d4a0;text-align:center;line-height:1.8;margin:0 0 3rem;max-width:700px;margin-left:auto;margin-right:auto}.bazaar-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:2.5rem}.bazaar-card{background:linear-gradient(135deg,#2a2a2a,#1f1f1f);border:3px solid #4a5c3a;padding:2rem;position:relative;box-shadow:5px 5px #0006,inset 0 0 20px #0000004d;transition:all .3s ease;clip-path:polygon(0 3%,3% 0,97% 0,100% 3%,100% 97%,97% 100%,3% 100%,0 97%)}.card-corner{position:absolute;top:10px;right:10px;width:12px;height:12px;background:#5a6a4a;border:2px solid #3a3a3a;transform:rotate(45deg);box-shadow:0 0 8px #4a5c3a99}.bazaar-card:before{content:"";position:absolute;top:0;left:0;width:100%;height:4px;background:linear-gradient(90deg,transparent,#5a6a4a,transparent);opacity:.7}.bazaar-card:after{content:"";position:absolute;bottom:0;right:0;width:4px;height:100%;background:linear-gradient(180deg,transparent,#4a5c3a,transparent);opacity:.7}.bazaar-card:hover{transform:translate(-4px,-4px);box-shadow:8px 8px #0009,inset 0 0 20px #0000004d;border-color:#5a6a4a}.bazaar-card:hover .card-corner{background:#6a7a5a;box-shadow:0 0 12px #6a7a5acc}.bazaar-card-title{font-family:Arial Black,Arial Bold,sans-serif;font-size:1.5rem;color:#e0d5b0;text-transform:uppercase;letter-spacing:1px;margin:0 0 1rem;text-shadow:2px 2px 4px rgba(0,0,0,.8);line-height:1.3}.bazaar-card-description{font-family:Arial,sans-serif;font-size:1rem;color:silver;line-height:1.7;margin:0 0 1.5rem}.bazaar-tags{display:flex;gap:.75rem;flex-wrap:wrap}.bazaar-tag{font-family:Arial Black,Arial,sans-serif;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:.4rem .9rem;background:#3a3a3a;border:2px solid #5a6a4a;color:#b8d4a0;clip-path:polygon(3% 0%,100% 0%,97% 100%,0% 100%);box-shadow:2px 2px #0006;transition:all .2s ease}.bazaar-tag:hover{background:#4a5c3a;color:#e0d5b0;transform:translateY(-2px)}@media (max-width: 768px){.bazaar-section{padding:3rem 1.5rem}.bazaar-grid{grid-template-columns:1fr;gap:2rem}.bazaar-card{padding:1.5rem}.bazaar-card-title{font-size:1.3rem}}.community-events,.gallery-section,.tickets-section{padding:5rem 2rem;position:relative}.community-events{background:linear-gradient(180deg,#1a1a1a,#2a2a1a)}.gallery-section{background:linear-gradient(180deg,#2a2a1a,#1a2a1a)}.tickets-section{background:linear-gradient(180deg,#1a2a1a,#2a3a2a)}.community-events:before,.gallery-section:before,.tickets-section:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,#4a5c3a,transparent)}.events-container,.gallery-container,.tickets-container{max-width:1200px;margin:0 auto}.events-intro,.gallery-intro,.tickets-intro{font-family:Arial,sans-serif;font-size:clamp(1.1rem,2vw,1.3rem);color:#b8d4a0;text-align:center;line-height:1.8;margin:0 0 3rem;max-width:700px;margin-left:auto;margin-right:auto}.events-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2.5rem;margin-bottom:3rem}.event-category{background:#2a2a2a;border:2px solid #4a5c3a;padding:2rem;box-shadow:4px 4px #0006;clip-path:polygon(0 0,100% 0,100% 95%,97% 100%,0 100%)}.event-category-title{font-family:Arial Black,Arial Bold,sans-serif;font-size:1.4rem;color:#e0d5b0;text-transform:uppercase;letter-spacing:1px;margin:0 0 1.5rem;padding-bottom:.75rem;border-bottom:2px solid #5a6a4a;text-shadow:2px 2px 4px rgba(0,0,0,.8)}.event-list{list-style:none;padding:0;margin:0}.event-item{font-family:Arial,sans-serif;font-size:1rem;color:silver;line-height:2;display:flex;align-items:center;gap:.75rem}.event-bullet{color:#5a6a4a;font-size:1.2rem;flex-shrink:0}.schedule-note{text-align:center;padding:2rem;background:#1f1f1f;border:2px solid #3a3a3a;border-left:4px solid #5a6a4a}.schedule-note p{font-family:Arial Black,Arial,sans-serif;font-size:1.1rem;color:#b8d4a0;margin:0;text-transform:uppercase;letter-spacing:1px}.gallery-placeholder{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem}.placeholder-box{aspect-ratio:4 / 3;background:linear-gradient(135deg,#2a2a2a,#1a1a1a);border:3px dashed #4a5c3a;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.placeholder-box:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:repeating-linear-gradient(45deg,transparent,transparent 10px,rgba(74,92,58,.1) 10px,rgba(74,92,58,.1) 20px)}.placeholder-text{font-family:Arial Black,Arial,sans-serif;font-size:1.2rem;color:#5a6a4a;text-transform:uppercase;letter-spacing:1px;position:relative;z-index:1}.tickets-placeholder{max-width:600px;margin:0 auto}.ticket-info{background:#2a2a2a;border:3px solid #4a5c3a;padding:3rem 2rem;text-align:center;box-shadow:6px 6px #0006;clip-path:polygon(0 0,100% 0,100% 97%,97% 100%,3% 100%,0 97%)}.ticket-info h3{font-family:Arial Black,Arial Bold,sans-serif;font-size:2rem;color:#e0d5b0;text-transform:uppercase;margin:0 0 1rem;text-shadow:2px 2px 4px rgba(0,0,0,.8)}.ticket-info p{font-family:Arial,sans-serif;font-size:1.1rem;color:silver;margin:0 0 2rem;line-height:1.6}.mailerlite-embed{width:100%;max-width:500px;margin:0 auto}.mailerlite-iframe{border:2px solid #4a5c3a;background:#1a1a1a;box-shadow:inset 2px 2px 4px #0006}.placeholder-form{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.email-input{font-family:Arial,sans-serif;font-size:1rem;padding:.875rem 1.5rem;background:#1a1a1a;border:2px solid #4a5c3a;color:#e0d5b0;min-width:250px;box-shadow:inset 2px 2px 4px #0006}.email-input::placeholder{color:#6a6a6a}.email-input:focus{outline:none;border-color:#5a6a4a;box-shadow:inset 2px 2px 4px #0006,0 0 0 2px #4a5c3a4d}.notify-button{font-family:Arial Black,Arial Bold,sans-serif;font-size:1rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;padding:.875rem 2rem;background:#5a6a4a;border:2px solid #d4c5a0;color:#fff;cursor:pointer;transition:all .3s ease;clip-path:polygon(5% 0%,100% 0%,95% 100%,0% 100%);box-shadow:3px 3px #00000080}.notify-button:hover{background:#6a7a5a;transform:translate(-2px,-2px);box-shadow:5px 5px #0009}.notify-button:active{transform:translate(1px,1px);box-shadow:2px 2px #00000080}@media (max-width: 768px){.community-events,.gallery-section,.tickets-section{padding:3rem 1.5rem}.events-grid,.gallery-placeholder{grid-template-columns:1fr;gap:1.5rem}.ticket-info{padding:2rem 1.5rem}.placeholder-form{flex-direction:column;align-items:stretch}.email-input{min-width:auto}}.footer{background:linear-gradient(180deg,#1a1a1a,#0a0a0a);border-top:3px solid #4a5c3a;padding:3rem 2rem 1.5rem;position:relative}.footer:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,#5a6a4a,transparent)}.footer-container{max-width:1200px;margin:0 auto}.footer-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:3rem;margin-bottom:2rem;padding-bottom:2rem;border-bottom:2px solid #2a2a2a}.footer-section{display:flex;flex-direction:column;gap:1rem}.footer-title{font-family:Impact,Franklin Gothic Bold,Arial,sans-serif;font-size:1.8rem;color:#d4c5a0;text-transform:uppercase;letter-spacing:2px;margin:0;text-shadow:2px 2px 4px rgba(0,0,0,.8)}.footer-description{font-family:Arial,sans-serif;font-size:.95rem;color:#999;line-height:1.6;margin:0}.footer-heading{font-family:Arial Black,Arial Bold,sans-serif;font-size:1.1rem;color:#b8d4a0;text-transform:uppercase;letter-spacing:1px;margin:0;text-shadow:1px 1px 2px rgba(0,0,0,.8)}.footer-links{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.footer-link{font-family:Arial,sans-serif;font-size:.95rem;color:#888;text-decoration:none;transition:all .2s ease;display:inline-block;position:relative;padding-left:0}.footer-link:before{content:"▸";position:absolute;left:-15px;color:#5a6a4a;opacity:0;transition:all .2s ease}.footer-link:hover{color:#d4c5a0;padding-left:15px}.footer-link:hover:before{opacity:1}.footer-bottom{text-align:center;padding-top:1.5rem}.footer-copyright{font-family:Arial,sans-serif;font-size:.9rem;color:#666;margin:0;text-transform:uppercase;letter-spacing:.5px}@media (max-width: 768px){.footer{padding:2rem 1.5rem 1rem}.footer-content{grid-template-columns:1fr;gap:2rem}.footer-title{font-size:1.5rem}}.App{position:relative}.App>section{position:relative;z-index:1}.App:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background-image:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.03) 2px,rgba(0,0,0,.03) 4px);pointer-events:none;z-index:9999;opacity:.3}*{margin:0;padding:0;box-sizing:border-box}:root{--color-sand: #d4c5a0;--color-sand-light: #e0d5b0;--color-grass: #b8d4a0;--color-forest: #5a6a4a;--color-forest-dark: #4a5c3a;--color-wasteland: #3a4a2a;--color-dust: #2a2a2a;--color-shadow: #1a1a1a;--color-night: #0a0a0a;--font-display: "Impact", "Franklin Gothic Bold", Arial, sans-serif;--font-heading: "Arial Black", "Arial Bold", sans-serif;--font-body: Arial, sans-serif}body{font-family:var(--font-body);background:var(--color-shadow);color:silver;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}html{scroll-behavior:smooth}::selection{background:var(--color-forest);color:var(--color-sand-light)}::-moz-selection{background:var(--color-forest);color:var(--color-sand-light)}::-webkit-scrollbar{width:12px}::-webkit-scrollbar-track{background:var(--color-shadow);border-left:1px solid var(--color-dust)}::-webkit-scrollbar-thumb{background:var(--color-forest-dark);border:2px solid var(--color-shadow)}::-webkit-scrollbar-thumb:hover{background:var(--color-forest)}.App{min-height:100vh;display:flex;flex-direction:column}.container{max-width:1400px;margin:0 auto;padding:0 2rem}button:focus-visible,a:focus-visible,input:focus-visible{outline:2px solid var(--color-grass);outline-offset:2px}button{border:none;background:none;font-family:inherit}a{color:var(--color-grass);text-decoration:none}a:hover{color:var(--color-sand)}img{max-width:100%;height:auto;display:block}h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.2}@media (max-width: 768px){.container{padding:0 1.5rem}}@media print{.topbar,.footer{display:none}}
