*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}:root{--black:#000000;--white:#ffffff;--red:#D83832;--green:#3a7a3b;--green-light:#529E53;--off-white:#f0ede8}html{scroll-behavior:smooth}body{background:var(--black);color:var(--white);font-family:'Noto Sans Thai',sans-serif;overflow-x:hidden}::-webkit-scrollbar{width:3px}::-webkit-scrollbar-track{background:var(--black)}::-webkit-scrollbar-thumb{background:var(--white)}#scrollBar{position:fixed;top:0;left:0;height:3px;width:0%;background:var(--red);z-index:200;transition:width 0.1s linear}nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:2.2rem 4rem;transition:padding 0.4s ease,background 0.4s ease}nav.scrolled{padding:1.1rem 4rem;background:rgba(0,0,0,0.93);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}.nav-logo{height:52px;width:auto;filter:invert(1);display:block;flex-shrink:0}.nav-links{display:flex;gap:2.5rem;list-style:none}.nav-links a{color:rgba(255,255,255,0.75);text-decoration:none;font-family:'Bebas Neue',sans-serif;font-size:1rem;letter-spacing:0.18em;transition:color 0.25s;position:relative}.nav-links a:hover{color:var(--white)}.nav-links a.nav-green{color:var(--green-light)}.nav-links a.nav-green:hover{color:#7bc87c}.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1px;background:var(--white);transition:width 0.3s ease}.nav-links a:hover::after{width:100%}#hero{position:relative;height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden}#heroCanvas{position:absolute;inset:0;z-index:1;pointer-events:none}.hero-bg{position:absolute;inset:-28%;background-image:url('/assets/images/firework.jpg');background-size:cover;background-position:center 30%;will-change:transform}.hero-overlay{position:absolute;inset:0;background:linear-gradient( to bottom,rgba(0,0,0,0.6) 0%,rgba(0,0,0,0.22) 35%,rgba(0,0,0,0.55) 70%,rgba(0,0,0,1) 100% )}.hero-content{position:relative;z-index:2;text-align:center;padding:0 2rem}.hero-eyebrow{font-family:'Noto Sans Thai',sans-serif;font-size:0.75rem;font-weight:500;letter-spacing:0.25em;text-transform:uppercase;color:rgba(255,255,255,0.4);margin-bottom:2.2rem;margin-top:5rem;opacity:0;transform:translateY(20px);animation:fadeUp 0.8s 0.3s forwards}.hero-logo-wrap{opacity:0;transform:translateY(30px);animation:fadeUp 0.9s 0.5s forwards}.hero-logo{width:min(780px,82vw);height:auto;filter:invert(1) drop-shadow(0 2px 40px rgba(255,255,255,0.12));display:block;margin:0 auto}.hero-tagline{font-family:'Noto Sans Thai',sans-serif;font-size:clamp(1rem,1.8vw,1.15rem);font-weight:300;color:rgba(255,255,255,0.6);margin-top:2.2rem;line-height:1.9;opacity:0;transform:translateY(20px);animation:fadeUp 0.8s 0.95s forwards}.hero-cta{display:inline-flex;gap:1rem;margin-top:3rem;opacity:0;animation:fadeUp 0.8s 1.15s forwards}.btn{display:inline-block;padding:0.9rem 2.4rem;font-family:'Noto Sans Thai',sans-serif;font-size:0.85rem;font-weight:600;letter-spacing:0.05em;text-decoration:none;transition:all 0.28s ease}.btn-white{background:var(--white);color:var(--black);border:1px solid var(--white)}.btn-white:hover{background:transparent;color:var(--white)}.btn-outline{background:transparent;color:var(--white);border:1px solid rgba(255,255,255,0.35)}.btn-outline:hover{border-color:var(--white)}.btn-black{background:var(--black);color:var(--white);border:1px solid var(--black)}.btn-black:hover{background:transparent;color:var(--black)}.btn-outline-dark{background:transparent;color:var(--black);border:1px solid rgba(0,0,0,0.3)}.btn-outline-dark:hover{border-color:var(--black)}.hero-scroll-hint{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:0.5rem;opacity:0;animation:fadeUp 0.8s 1.6s forwards}.hero-scroll-hint span{font-family:'Bebas Neue',sans-serif;font-size:0.7rem;letter-spacing:0.35em;color:rgba(255,255,255,0.3)}.scroll-line{width:1px;height:50px;background:linear-gradient(to bottom,rgba(255,255,255,0.45),transparent);animation:scrollPulse 2s infinite}.marquee-strip{background:var(--white);color:var(--black);padding:0.9rem 0;overflow:hidden;white-space:nowrap}.marquee-track{display:inline-flex;align-items:center;animation:marquee 24s linear infinite}.marquee-item{font-family:'Bebas Neue',sans-serif;font-size:1rem;letter-spacing:0.12em;padding:0 2rem;line-height:1;display:inline-flex;align-items:center}.marquee-dot{color:var(--red)}.marquee-item-th{font-family:'Noto Sans Thai',sans-serif;font-size:0.82rem;font-weight:500;letter-spacing:0.06em}.section-label{font-family:'Bebas Neue',sans-serif;font-size:0.75rem;letter-spacing:0.4em;color:rgba(255,255,255,0.48);margin-bottom:1.2rem}.section-label.on-light{color:rgba(0,0,0,0.48)}.section-label.on-green{color:var(--green-light)}h2.display{font-family:'Kanit',sans-serif;font-size:clamp(2.8rem,5.5vw,5.5rem);font-weight:500;line-height:1.0}.clip-reveal{clip-path:inset(0 0 100% 0);transition:clip-path 0.9s cubic-bezier(0.16,1,0.3,1)}.clip-reveal.visible{clip-path:inset(0 0 0% 0)}.draw-line{height:1px;background:var(--red);width:0;transition:width 1.2s ease;margin-bottom:2rem}.draw-line.visible{width:100%}#about{padding:10rem 0 8rem;background:var(--black)}.about-inner{max-width:1400px;margin:0 auto;padding:0 4rem}.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:7rem;align-items:start}.about-headline{font-family:'Kanit',sans-serif;font-size:clamp(3rem,5vw,5rem);font-weight:500;line-height:1.05;margin-top:1rem}.about-headline em{font-style:italic;color:var(--red)}.about-body{margin-top:1.8rem;font-family:'Noto Sans Thai',sans-serif;font-size:1rem;font-weight:300;line-height:2.0;color:rgba(255,255,255,0.78)}.stat-row{display:flex;gap:3rem;margin-top:3.5rem;padding-top:3rem;border-top:1px solid rgba(255,255,255,0.1)}.stat-num{font-family:'Bebas Neue',sans-serif;font-size:3.8rem;line-height:1;color:var(--white)}.stat-num span:first-child{color:var(--red)}.stat-num span:last-child{color:var(--white)}.stat-label{font-family:'Bebas Neue',sans-serif;font-size:0.7rem;letter-spacing:0.2em;color:rgba(255,255,255,0.48);margin-top:0.3rem}.pillars-label{font-family:'Bebas Neue',sans-serif;font-size:0.75rem;letter-spacing:0.4em;color:rgba(255,255,255,0.48);margin-bottom:1.5rem}.pillars{display:flex;flex-direction:column}.pillar{display:flex;gap:1.5rem;padding:1.35rem 0;border-bottom:1px solid rgba(255,255,255,0.07);opacity:0;transform:translateX(28px);transition:opacity 0.55s ease,transform 0.55s ease}.pillar.visible{opacity:1;transform:translateX(0)}.pillar-num{font-family:'Bebas Neue',sans-serif;font-size:2rem;color:rgba(255,255,255,0.45);min-width:2.6rem;line-height:1;padding-top:3px}.pillar-title{font-family:'Bebas Neue',sans-serif;font-weight:normal;font-size:1rem;letter-spacing:0.12em;color:var(--white);margin-bottom:0.4rem}.pillar-desc{font-family:'Noto Sans Thai',sans-serif;font-size:0.85rem;font-weight:300;line-height:1.75;color:rgba(255,255,255,0.72)}.big-text-divider{overflow:hidden;background:var(--black);padding:4rem 0;white-space:nowrap;border-top:1px solid rgba(255,255,255,0.05);border-bottom:1px solid rgba(255,255,255,0.05)}.big-text-inner{display:inline-flex;animation:marquee 38s linear infinite}.big-text-item{font-family:'Kanit',sans-serif;font-size:clamp(4.5rem,10vw,10.5rem);font-weight:500;letter-spacing:-0.02em;color:transparent;-webkit-text-stroke:1px rgba(255,255,255,0.08);padding:0 2rem}.big-text-item.accent{-webkit-text-stroke:1px rgba(217,26,26,0.22)}#festivals{background:var(--black);padding:4rem 0 0}.festivals-header{max-width:1400px;margin:0 auto;padding:0 4rem 4rem}.festival-scene{height:200vh;position:relative}.festival-block{position:sticky;top:0;height:100vh;overflow:hidden;display:flex;align-items:center;margin-bottom:0}.festival-bg{position:absolute;inset:-30%;background-size:cover;background-position:center;will-change:transform;opacity:0;transform:scale(1.1);transition:opacity 1s ease,transform 1.1s ease}.festival-block.bg-visible .festival-bg{opacity:1;transform:scale(1)}.festival-content{will-change:transform;opacity:0;transform:translateY(40px);transition:opacity 0.75s ease,transform 0.75s ease}.festival-block.content-visible .festival-content{opacity:1;transform:translateY(0)}.festival-tint{position:absolute;inset:0}.festival-tint.red{background:linear-gradient(130deg,rgba(155,0,0,0.55) 0%,rgba(0,0,0,0.65) 100%)}.festival-tint.green{background:linear-gradient(130deg,rgba(0,65,22,0.55) 0%,rgba(0,0,0,0.65) 100%)}.festival-tint.dark{background:rgba(0,0,0,0.58)}.festival-content{position:relative;z-index:2;padding:0 5rem;max-width:680px}.festival-tag{display:inline-block;padding:0.3rem 1rem;font-family:'Bebas Neue',sans-serif;font-size:0.75rem;letter-spacing:0.2em;margin-bottom:1.3rem;background:var(--red)}.festival-tag.green-tag{background:var(--green)}.festival-title{font-family:'Kanit',sans-serif;font-size:clamp(3.2rem,6.5vw,7rem);font-weight:500;line-height:0.95;margin-bottom:1.2rem}.festival-meta{font-family:'Bebas Neue',sans-serif;font-size:0.85rem;letter-spacing:0.14em;color:rgba(255,255,255,0.72);margin-bottom:1.1rem}.festival-desc{font-family:'Noto Sans Thai',sans-serif;font-size:0.95rem;font-weight:300;line-height:1.95;color:rgba(255,255,255,0.78)}.festival-artists{display:flex;flex-wrap:wrap;gap:0.45rem;margin-top:1.5rem}.artist-chip{padding:0.25rem 0.8rem;border:1px solid rgba(255,255,255,0.2);font-family:'Bebas Neue',sans-serif;font-size:0.78rem;letter-spacing:0.1em;color:rgba(255,255,255,0.72)}#green{background:var(--black)}.green-block{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden}.green-bg-img{position:absolute;inset:-30%;background-image:url('/assets/images/heavy-green.jpg');background-size:cover;background-position:center;will-change:transform;filter:brightness(0.18) saturate(0.2)}.green-overlay{position:absolute;inset:0;background:linear-gradient(105deg,rgba(0,0,0,0.97) 42%,rgba(0,35,12,0.72) 100%)}.green-content{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:center;max-width:1400px;margin:0 auto;padding:8rem 4rem;width:100%}.green-headline{font-family:'Kanit',sans-serif;font-size:clamp(3rem,5.5vw,5.5rem);font-weight:500;line-height:1.0;margin:1rem 0 2rem}.green-headline em{font-style:normal;color:var(--green-light)}.green-body{font-family:'Noto Sans Thai',sans-serif;font-size:0.97rem;font-weight:300;line-height:2.0;color:rgba(255,255,255,0.78);margin-bottom:1.4rem}.green-quote{font-family:'Noto Sans Thai',sans-serif;font-size:0.88rem;font-weight:400;font-style:italic;color:rgba(255,255,255,0.65);line-height:1.8;margin-bottom:1.8rem}.sdg-badge{display:inline-flex;align-items:center;gap:0.75rem;padding:0.8rem 1.3rem;border:1px solid var(--green-light)}.sdg-dot{width:7px;height:7px;background:var(--green-light);border-radius:50%;flex-shrink:0}.sdg-text{font-family:'Bebas Neue',sans-serif;font-size:0.72rem;letter-spacing:0.15em;color:var(--green-light)}.eco-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:rgba(255,255,255,0.06);margin-top:2.5rem}.eco-cell{background:#050505;padding:1.3rem 1.2rem}.eco-icon{width:26px;height:26px;margin-bottom:0.7rem;color:var(--green-light)}.eco-icon svg{width:100%;height:100%;display:block}.eco-title{font-family:'Bebas Neue',sans-serif;font-size:0.85rem;letter-spacing:0.12em;color:var(--green-light);margin-bottom:0.35rem}.eco-desc{font-family:'Noto Sans Thai',sans-serif;font-size:0.78rem;font-weight:300;color:rgba(255,255,255,0.65);line-height:1.6}.cert-wrap{display:flex;justify-content:center;align-items:center}.cert-card{background:var(--white);padding:1.8rem;max-width:360px;width:100%;box-shadow:0 0 100px rgba(42,180,80,0.18);opacity:0;transform:translateY(40px) rotate(1.5deg);transition:opacity 0.9s ease,transform 0.9s ease}.cert-card.visible{opacity:1;transform:translateY(0) rotate(0deg)}.cert-card img{width:100%;display:block}#process{background:var(--off-white);color:var(--black);padding:8rem 0;overflow:hidden}.process-header{max-width:1400px;margin:0 auto 4rem;padding:0 4rem}.process-header h2.display{color:var(--black)}.process-header p{font-family:'Noto Sans Thai',sans-serif;font-size:0.97rem;font-weight:300;color:rgba(0,0,0,0.65);margin-top:1.5rem;max-width:460px;line-height:1.9}.hscroll-track{display:flex;gap:2px;padding:0 4rem;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;cursor:grab}.hscroll-track::-webkit-scrollbar{display:none}.hscroll-track.grabbing{cursor:grabbing}.process-card{flex-shrink:0;width:305px;scroll-snap-align:start;background:var(--black);color:var(--white);padding:2.5rem 2rem;position:relative;overflow:hidden;transition:transform 0.3s ease}.process-card:hover{transform:translateY(-5px)}.process-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform 0.4s ease}.process-card:hover::after{transform:scaleX(1)}.process-bg-num{font-family:'Bebas Neue',sans-serif;font-size:5rem;color:rgba(255,255,255,0.18);line-height:1;position:absolute;top:1rem;right:1.5rem}.process-icon{width:28px;height:28px;color:rgba(255,255,255,0.78);margin-bottom:1.5rem}.process-icon svg{width:100%;height:100%;display:block}.process-title{font-family:'Bebas Neue',sans-serif;font-size:1.9rem;letter-spacing:0.08em;margin-bottom:1rem}.process-desc{font-family:'Noto Sans Thai',sans-serif;font-size:0.83rem;font-weight:300;line-height:1.75;color:rgba(255,255,255,0.72)}#gallery{background:var(--black);padding:8rem 0}.gallery-header{max-width:1400px;margin:0 auto 4rem;padding:0 4rem}.photo-grid{display:grid;grid-template-columns:repeat(12,1fr);grid-template-rows:repeat(3,260px);gap:3px;max-width:1400px;margin:0 auto;padding:0 4rem}.photo-cell{overflow:hidden}.photo-cell img{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(25%);transition:transform 0.7s ease,filter 0.5s ease}.photo-cell:hover img{transform:scale(1.07);filter:grayscale(0%)}.photo-cell:nth-child(1){grid-column:1 / 6;grid-row:1 / 3}.photo-cell:nth-child(2){grid-column:6 / 9;grid-row:1 / 2}.photo-cell:nth-child(3){grid-column:9 / 13;grid-row:1 / 2}.photo-cell:nth-child(4){grid-column:6 / 10;grid-row:2 / 4}.photo-cell:nth-child(5){grid-column:10/ 13;grid-row:2 / 3}.photo-cell:nth-child(6){grid-column:1 / 4;grid-row:3 / 4}.photo-cell:nth-child(7){grid-column:4 / 6;grid-row:3 / 4}.photo-cell:nth-child(8){grid-column:10/ 13;grid-row:3 / 4}#contact{background:var(--white);color:var(--black);padding:8rem 4rem}.contact-inner{max-width:1400px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:start}.contact-headline{font-family:'Kanit',sans-serif;font-size:clamp(3rem,5vw,5rem);font-weight:500;line-height:1.05;color:var(--black);margin-top:1rem}.contact-headline em{font-style:italic;color:var(--red)}.contact-body{font-family:'Noto Sans Thai',sans-serif;font-size:0.97rem;font-weight:300;line-height:2.0;color:rgba(0,0,0,0.68);margin-top:1.8rem;max-width:420px}.contact-actions{display:flex;gap:1rem;margin-top:3rem}.ticket{background:var(--black);color:var(--white);display:flex;position:relative;overflow:visible;margin-top:2rem}.ticket::before,.ticket::after{content:'';position:absolute;width:22px;height:22px;background:var(--white);border-radius:50%;left:calc(160px - 11px);z-index:2}.ticket::before{top:-11px}.ticket::after{bottom:-11px}.ticket-stub{width:160px;flex-shrink:0;padding:2rem 1.2rem;border-right:2px dashed rgba(255,255,255,0.2);display:flex;flex-direction:column;align-items:center;justify-content:space-between;gap:1.5rem}.ticket-stub-title{font-family:'Bebas Neue',sans-serif;font-size:0.65rem;letter-spacing:0.35em;color:rgba(255,255,255,0.4);writing-mode:vertical-rl;text-orientation:mixed;transform:rotate(180deg)}.ticket-stub-num{display:flex;flex-direction:column;align-items:center;gap:0.3rem}.ticket-stub-h{font-family:'Bebas Neue',sans-serif;font-size:3rem;line-height:1;color:var(--red)}.ticket-stub-sdg{width:52px;height:auto;display:block}.ticket-stub-admit{font-family:'Bebas Neue',sans-serif;font-size:0.6rem;letter-spacing:0.3em;color:rgba(255,255,255,0.3);text-align:center}.ticket-body{flex:1;padding:2rem 2.2rem;display:flex;flex-direction:column;gap:0}.ticket-header{display:flex;align-items:baseline;justify-content:space-between;padding-bottom:1.2rem;border-bottom:1px solid rgba(255,255,255,0.1);margin-bottom:1.2rem}.ticket-event-name{font-family:'Bebas Neue',sans-serif;font-size:1.6rem;letter-spacing:0.08em}.ticket-event-sub{font-family:'Bebas Neue',sans-serif;font-size:0.65rem;letter-spacing:0.3em;color:rgba(255,255,255,0.35)}.ticket-fields{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1.4rem 2rem}.ticket-field{display:flex;flex-direction:column;gap:0.3rem}.ticket-field.span2{grid-column:span 2}.ticket-field-label{font-family:'Bebas Neue',sans-serif;font-size:0.58rem;letter-spacing:0.3em;color:rgba(255,255,255,0.35)}.ticket-field-val{font-family:'Kanit',sans-serif;font-size:0.92rem;font-weight:500;color:var(--white);line-height:1.25}.ticket-field-val a{color:var(--white);text-decoration:none;border-bottom:1px solid rgba(255,255,255,0.25);transition:color 0.2s,border-color 0.2s}.ticket-field-val a:hover{color:var(--red);border-color:var(--red)}.ticket-barcode{margin-top:1.6rem;padding-top:1.2rem;border-top:1px solid rgba(255,255,255,0.1);display:flex;align-items:center;gap:1.4rem}.barcode-lines{display:flex;gap:2px;align-items:stretch;height:36px}.barcode-lines span{display:block;width:2px;background:rgba(255,255,255,0.7)}.barcode-lines span:nth-child(even){height:70%;align-self:center;opacity:0.4}.barcode-lines span:nth-child(3n){width:4px}.barcode-lines span:nth-child(5n){width:1px;opacity:0.3}.ticket-barcode-text{font-family:'Bebas Neue',sans-serif;font-size:0.6rem;letter-spacing:0.3em;color:rgba(255,255,255,0.25)}.partner-badge{margin-top:3px;display:flex;align-items:stretch;background:var(--white);border:1px solid rgba(0,0,0,0.1)}.partner-stub{width:160px;flex-shrink:0;border-right:2px dashed rgba(0,0,0,0.15);display:flex;align-items:center;justify-content:center;padding:1.2rem}.partner-label{font-family:'Bebas Neue',sans-serif;font-size:0.62rem;letter-spacing:0.3em;color:rgba(0,0,0,0.35);text-align:center;line-height:1.6}.partner-body{flex:1;display:flex;align-items:center;gap:1.4rem;padding:1.2rem 2.2rem}.partner-divider{width:1px;height:32px;background:rgba(0,0,0,0.12);flex-shrink:0}.partner-logo{height:44px;width:auto;display:block}.partner-url{font-family:'Bebas Neue',sans-serif;font-size:0.72rem;letter-spacing:0.15em;color:rgba(0,0,0,0.4);text-decoration:none;margin-left:auto;transition:color 0.2s}.partner-url:hover{color:var(--black)}footer{background:var(--black);padding:2.5rem 4rem;display:flex;align-items:center;justify-content:space-between}.footer-left{display:flex;align-items:center;gap:1rem}.footer-logo{height:34px;width:auto;filter:invert(1);display:block}.footer-fb{display:inline-flex;align-items:center;color:rgba(255,255,255,0.6);transition:color 0.25s}.footer-fb:hover{color:var(--white)}.footer-fb svg{width:18px;height:18px;display:block}.footer-middle{font-family:'Bebas Neue',sans-serif;font-size:1.1rem;letter-spacing:0.2em;color:rgba(255,255,255,0.65)}.footer-copy{font-family:'Bebas Neue',sans-serif;font-size:0.7rem;letter-spacing:0.18em;color:rgba(255,255,255,0.55)}.reveal{opacity:0;transform:translateY(38px);transition:opacity 0.7s ease,transform 0.7s ease}.reveal.visible{opacity:1;transform:translateY(0)}.rd1{transition-delay:0.1s}.rd2{transition-delay:0.2s}.rd3{transition-delay:0.3s}.rd4{transition-delay:0.4s}@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}@keyframes scrollPulse{0%,100%{opacity:0.4}50%{opacity:1}}@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}@media (max-width:960px){nav{padding:1.2rem 1.5rem}nav.scrolled{padding:0.8rem 1.5rem}.nav-links{display:none}.about-inner,.festivals-header,.gallery-header,.process-header{padding:0 1.5rem}.hscroll-track{padding:0 1.5rem}.photo-grid{padding:0 1.5rem;grid-template-columns:1fr 1fr;grid-template-rows:auto}.photo-cell{grid-column:auto !important;grid-row:auto !important;height:200px}.about-grid,.green-content,.contact-inner{grid-template-columns:1fr;gap:3rem}.green-content{padding:5rem 1.5rem}.cert-wrap{display:none}#contact{padding:5rem 1.5rem}footer{flex-direction:column;gap:1.2rem;text-align:center;padding:2rem}.festival-content{padding:0 1.5rem}}