@import "https://fonts.googleapis.com/css2?family=Lora:wght@600;700;800&family=DM+Sans:ital,wght@0,400;0,500;1,400&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--color-primary:#c0714a;--color-primary-dark:#a85c38;--color-primary-light:#f0e6d8;--color-primary-border:#c0714a4d;--color-bg:#fdf6ee;--color-bg-alt:#f7ede0;--color-surface:#fff;--color-input-bg:#faf3ea;--color-border:#d4b896;--color-text:#2c1810;--color-muted:#8a6a55;--color-success:#4a7c59;--color-success-light:#e8f2eb;--color-success-border:#7aaa8a;--color-warning-bg:#fff8e1;--color-warning-bdr:#ffa726;--color-warning-txt:#bf360c;--card-shadow:0 2px 6px #2c18101a;--radius:12px;--font-display:"Lora", Georgia, serif;--font-body:"DM Sans", -apple-system, BlinkMacSystemFont, sans-serif}body{font-family:var(--font-body);background:var(--color-bg);background-attachment:fixed;min-height:100vh}.navbar{z-index:200;background:var(--color-surface);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;height:60px;padding:0 32px;display:flex;position:sticky;top:0}.navbar__logo{color:var(--color-primary);letter-spacing:-.5px;font-size:22px;font-weight:800;text-decoration:none}.navbar__tabs{background:var(--color-primary-light);border-radius:10px;align-items:center;gap:0;padding:4px;display:flex;position:relative}.navbar__tab{z-index:1;cursor:pointer;color:var(--color-muted);white-space:nowrap;background:0 0;border:none;border-radius:7px;padding:7px 18px;font-size:13px;font-weight:600;transition:color .2s;position:relative}.navbar__tab:hover,.navbar__tab.active{color:var(--color-primary)}.navbar__tab-slider{background:var(--color-surface);pointer-events:none;border-radius:7px;height:calc(100% - 8px);transition:transform .25s cubic-bezier(.4,0,.2,1),width .25s cubic-bezier(.4,0,.2,1);position:absolute;top:4px;left:4px;box-shadow:0 1px 4px #0000001a}.container{max-width:1200px;margin:0 auto;padding:36px 32px}.page-title{color:var(--color-primary);margin-bottom:4px;font-size:24px;font-weight:800}.page-sub{color:var(--color-muted);margin-bottom:28px;font-size:14px}.events-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;display:grid}.event-card{background:var(--color-surface);border-radius:var(--radius);box-shadow:var(--card-shadow);cursor:pointer;border:1.5px solid #0000;transition:transform .15s,box-shadow .15s;overflow:hidden}.event-card:hover{border-color:var(--color-primary-border);transform:translateY(-2px);box-shadow:0 6px 20px #c0714a26}.event-card__banner{justify-content:center;align-items:center;height:140px;display:flex;position:relative}.banner-free{background:linear-gradient(135deg,#5c3d2e 0%,#8b5a3a 100%)}.banner-paid{background:linear-gradient(135deg,#7a4a2e 0%,#b5722e 100%)}.event-card__banner-icon{opacity:.6;font-size:40px}.event-card__badge{border-radius:20px;padding:4px 10px;font-size:11px;font-weight:700;position:absolute;top:10px;right:10px}.badge-free{background:var(--color-primary-light);color:var(--color-primary);border:1.5px solid var(--color-primary-border)}.badge-price{background:var(--color-warning-bg);color:var(--color-warning-txt);border:1.5px solid var(--color-warning-bdr)}.badge-sold-out{color:var(--color-muted);background:#f3f4f6;border:1.5px solid #d1d5db}.badge-going{background:var(--color-success);color:#fff;border:1.5px solid var(--color-success)}.event-card__body{padding:16px}.event-card__name{color:var(--color-text);margin-bottom:6px;font-size:16px;font-weight:700;line-height:1.3}.event-card__meta{color:var(--color-muted);flex-direction:column;gap:4px;font-size:12px;display:flex}.pill-row{flex-wrap:wrap;gap:8px;margin-top:10px;display:flex}.pill{border-radius:20px;align-items:center;gap:4px;padding:4px 10px;font-size:11px;font-weight:700;display:flex}.pill-green{background:var(--color-success-light);color:var(--color-success);border:1.5px solid var(--color-success-border)}.pill-orange{background:var(--color-warning-bg);color:var(--color-warning-txt);border:1.5px solid var(--color-warning-bdr)}.pill-blue{background:var(--color-primary-light);color:var(--color-primary);border:1.5px solid var(--color-primary-border)}.pill-sold-out{color:var(--color-muted);background:#f3f4f6;border:1.5px solid #d1d5db}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.skeleton{background:linear-gradient(90deg,#f0e6d8 25%,#faf3ea 50%,#f0e6d8 75%) 0 0/800px 100%;border-radius:6px;animation:1.4s infinite shimmer}.skeleton-card{background:var(--color-surface);border-radius:var(--radius);box-shadow:var(--card-shadow);overflow:hidden}.skeleton-banner{height:140px}.skeleton-body{flex-direction:column;gap:10px;padding:16px;display:flex}.skeleton-line{height:14px}.skeleton-line--short{width:60%}.skeleton-line--medium{width:80%}.empty-state{text-align:center;color:var(--color-muted);padding:60px 20px;font-size:15px}.error-state{text-align:center;flex-direction:column;align-items:center;gap:14px;padding:60px 20px;display:flex}.error-state p{color:var(--color-muted);font-size:15px}.error-state button{background:var(--color-primary-dark);color:#fff;cursor:pointer;border:none;border-radius:10px;padding:10px 24px;font-size:14px;font-weight:600}.error-state button:hover{background:var(--color-primary)}.loading-state{text-align:center;color:var(--color-muted);padding:80px 20px;font-size:15px}.back-btn{color:var(--color-primary);cursor:pointer;background:0 0;border:none;align-items:center;gap:8px;margin-bottom:20px;padding:0;font-size:14px;font-weight:600;display:inline-flex}.back-btn:hover{opacity:.7}.detail-layout{grid-template-columns:1fr 340px;align-items:start;gap:24px;display:grid}@media (width<=780px){.detail-layout{grid-template-columns:1fr}}.detail-banner{aspect-ratio:16/9;border-radius:var(--radius);justify-content:center;align-items:center;width:100%;margin-bottom:20px;display:flex;overflow:hidden}.detail-banner img{object-fit:cover;width:100%;height:100%}.detail-banner__icon{opacity:.5;font-size:80px}.detail-title{color:var(--color-text);margin-bottom:10px;font-size:28px;font-weight:800}.info-card{background:var(--color-surface);border-radius:var(--radius);box-shadow:var(--card-shadow);align-items:center;gap:14px;margin-bottom:10px;padding:14px 16px;display:flex}.info-card__icon{background:var(--color-primary-light);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:20px;display:flex}.info-card__label{color:var(--color-muted);font-size:11px}.info-card__value{color:var(--color-text);font-size:14px;font-weight:600}.about-card{border:1.5px solid var(--color-primary-border);border-radius:var(--radius);margin-top:10px;padding:18px}.about-card__title{color:var(--color-text);margin-bottom:10px;font-size:15px;font-weight:700}.about-card__text{color:var(--color-muted);white-space:pre-wrap;font-size:14px;line-height:1.6}.attendees-section{border:1.5px solid var(--color-primary-border);border-radius:var(--radius);margin-top:10px;padding:18px}.attendees-title{color:var(--color-text);margin-bottom:12px;font-size:15px;font-weight:700}.attendee-list{flex-direction:column;gap:10px;max-height:220px;display:flex;overflow-y:auto}.attendee{align-items:center;gap:12px;display:flex}.attendee__avatar{background:var(--color-primary-light);width:36px;height:36px;color:var(--color-primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;font-weight:700;display:flex}.attendee__name{color:var(--color-text);font-size:14px}.reg-card{background:var(--color-surface);border:1.5px solid var(--color-primary-border);border-radius:var(--radius);padding:20px;position:sticky;top:80px}.reg-card__title{color:var(--color-text);margin-bottom:16px;font-size:15px;font-weight:700}.reg-card__price{color:var(--color-primary);margin-bottom:4px;font-size:28px;font-weight:800}.reg-card__price-label{color:var(--color-muted);margin-bottom:18px;font-size:12px}.btn-rsvp{background:var(--color-primary-dark);color:#fff;cursor:not-allowed;opacity:.6;border:none;border-radius:10px;justify-content:center;align-items:center;gap:8px;width:100%;margin-bottom:10px;padding:14px;font-size:15px;font-weight:600;display:flex}.sold-out-banner{width:100%;color:var(--color-muted);text-align:center;background:#f3f4f6;border:1.5px solid #d1d5db;border-radius:10px;margin-bottom:10px;padding:14px;font-size:15px;font-weight:700}.reg-card__note{color:var(--color-muted);text-align:center;margin-top:12px;font-size:12px;line-height:1.5}.btn-going{background:var(--color-success-light);width:100%;color:var(--color-success);border:1.5px solid var(--color-success-border);text-align:center;border-radius:10px;margin-bottom:8px;padding:14px;font-size:15px;font-weight:700}.reg-card__cancel{width:100%;color:var(--color-muted);cursor:pointer;text-align:center;background:0 0;border:none;margin-bottom:8px;padding:6px;font-size:13px;text-decoration:underline;display:block}.reg-card__cancel:hover{color:#dc2626}.reg-card__error{color:#dc2626;text-align:center;margin-top:8px;font-size:12px}.btn-rsvp--cancelled{pointer-events:auto;color:#fff!important;cursor:not-allowed!important;background:#9ca3af!important}.btn-rsvp:not(:disabled){cursor:pointer;opacity:1}.btn-rsvp:not(:disabled):hover{background:var(--color-primary)}.navbar__user{align-items:center;gap:8px;display:flex}.navbar__user-name{color:var(--color-primary);padding:7px 12px;font-size:13px;font-weight:700}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000073;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal{background:var(--color-surface);border-radius:20px;width:100%;max-width:420px;max-height:90vh;padding:36px 32px 28px;position:relative;overflow-y:auto;box-shadow:0 24px 60px #0000002e}.modal__close{background:var(--color-primary-light);cursor:pointer;width:28px;height:28px;color:var(--color-muted);border:none;border-radius:50%;justify-content:center;align-items:center;font-size:16px;line-height:1;transition:background .15s,color .15s;display:flex;position:absolute;top:14px;right:16px}.modal__close:hover{background:var(--color-border);color:var(--color-text)}.modal__title{color:var(--color-primary);letter-spacing:-.3px;margin-bottom:20px;font-size:22px;font-weight:800}.modal__subtitle{color:var(--color-text);margin-bottom:6px;font-size:15px;line-height:1.5}.modal__subtitle strong{color:var(--color-primary)}.modal__hint{color:var(--color-muted);margin-bottom:20px;font-size:12px;font-style:italic}.modal__legal{color:var(--color-muted);margin-bottom:18px;font-size:12px;line-height:1.5}.modal__legal a{color:var(--color-primary);font-weight:600}.modal__resend{text-align:center;color:var(--color-muted);margin-top:14px;font-size:13px}.form-field{flex-direction:column;gap:5px;margin-bottom:14px;display:flex}.form-field label{color:var(--color-text);font-size:13px;font-weight:600}.form-field input{border:1.5px solid var(--color-border);color:var(--color-text);background:var(--color-input-bg);border-radius:10px;outline:none;width:100%;padding:11px 14px;font-size:14px;transition:border-color .15s,box-shadow .15s}.form-field input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-border);background:var(--color-surface)}.field-error{color:#dc2626;align-items:center;gap:4px;font-size:12px;display:flex}.field-error:before{content:"⚠";font-size:11px}.btn-primary{cursor:pointer;background:var(--color-primary-dark);color:#fff;border:none;border-radius:10px;width:100%;margin-top:4px;padding:13px;font-size:15px;font-weight:700;transition:background .15s,transform .1s}.btn-primary:hover:not(:disabled){background:var(--color-primary)}.btn-primary:active:not(:disabled){transform:scale(.98)}.btn-primary:disabled{opacity:.55;cursor:not-allowed}.btn-link{cursor:pointer;color:var(--color-primary);text-align:center;background:0 0;border:none;margin:10px auto 0;padding:0;font-size:13px;font-weight:600;text-decoration:underline;display:block}.btn-link:hover{opacity:.75}.otp-success-icon{width:64px;height:64px;margin:0 auto 16px}.otp-success-icon svg{width:100%;height:100%}.otp-boxes{justify-content:center;gap:10px;margin:20px 0 0;display:flex}.otp-box{border:2px solid var(--color-border);background:var(--color-input-bg);text-align:center;width:48px;height:58px;color:var(--color-primary);caret-color:var(--color-primary);border-radius:12px;outline:none;font-size:22px;font-weight:700;transition:border-color .15s,box-shadow .15s,background .15s}.otp-box:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-border);background:var(--color-surface)}.otp-box--error{border-color:#dc2626}.otp-box:disabled{background:var(--color-primary-light);border-color:var(--color-border)}.toast{z-index:2000;background:var(--color-primary-dark);color:#fff;white-space:nowrap;border-radius:10px;padding:12px 24px;font-size:14px;font-weight:500;animation:.2s toast-in;position:fixed;bottom:24px;left:50%;transform:translate(-50%);box-shadow:0 8px 24px #0000002e}@keyframes toast-in{0%{opacity:0;transform:translate(-50%)translateY(8px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.legal-overlay{z-index:1100}.legal-modal{flex-direction:column;width:calc(100% - 32px);max-width:480px;max-height:80vh;padding:0;display:flex;overflow:hidden}.legal-modal__header{border-bottom:1px solid #f0f0f4;flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 20px 12px;display:flex}.legal-modal__title{color:var(--color-primary);font-size:16px;font-weight:700}.legal-modal__close{width:28px;height:28px;font-size:18px;position:static}.legal-modal__date{color:var(--color-muted);margin-bottom:10px;font-size:11px;font-style:italic}.legal-modal__body{flex:1;padding:12px 20px 20px;overflow-y:auto}.legal-section{margin-bottom:14px}.legal-section__title{color:var(--color-text);margin-bottom:4px;font-size:13px;font-weight:700}.legal-section__body{color:var(--color-muted);white-space:pre-line;font-size:13px;line-height:1.6}.btn-link--inline{font-size:inherit;vertical-align:baseline;padding:0;text-decoration:underline;display:inline}.modal__title--centered{text-align:center}.btn-primary--mt{margin-top:20px}.resend__sent-label{color:var(--color-primary);font-weight:600}.otp-error{text-align:center;margin-top:10px;display:block}.modal-overlay--warm{background:#2c18108c}.modal--warm{background:var(--color-bg);border:1px solid var(--color-border);box-shadow:0 24px 60px #2c181038}.modal--warm .modal__close{background:var(--color-primary-light);color:var(--color-muted)}.modal--warm .modal__close:hover{background:var(--color-border);color:var(--color-text)}.modal--warm .modal__title,.modal--warm .modal__subtitle{color:var(--color-text)}.modal--warm .modal__subtitle strong{color:var(--color-primary)}.modal--warm .modal__hint,.modal--warm .modal__legal{color:var(--color-muted)}.modal--warm .form-field label{color:var(--color-text);font-weight:600}.modal--warm .form-field input{background:var(--color-input-bg);border-color:var(--color-border);color:var(--color-text)}.modal--warm .form-field input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-border);background:var(--color-bg)}.modal--warm .btn-primary{background:var(--color-primary)}.modal--warm .btn-primary:hover:not(:disabled){background:var(--color-primary-dark)}.modal--warm .btn-link,.modal--warm .btn-link--inline,.modal--warm .resend__sent-label{color:var(--color-primary)}.modal--warm .otp-box{background:var(--color-input-bg);border-color:var(--color-border);color:var(--color-text);caret-color:var(--color-primary)}.modal--warm .otp-box:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-border);background:var(--color-bg)}.modal--warm .otp-success-icon circle{fill:#c0714a26}.modal--warm .otp-success-icon path{stroke:var(--color-primary)}@media (width<=768px){.modal-overlay--warm{align-items:flex-end;padding:0}.modal--warm{border-radius:24px 24px 0 0;max-width:100%;max-height:92vh;animation:.32s cubic-bezier(.32,.72,0,1) modal-slide-up}@media (prefers-reduced-motion:reduce){.modal--warm{animation:none}}}@keyframes modal-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.confirm-overlay{z-index:1200}.confirm-modal{max-width:400px;padding:28px 24px 24px}.confirm-modal__message{color:var(--color-text);margin-bottom:24px;font-size:16px;line-height:1.5}.confirm-modal__actions{justify-content:flex-end;gap:12px;display:flex}.payment-modal{max-width:560px;padding:32px 36px 28px}.payment-modal__title{color:var(--color-text);margin-bottom:24px;font-size:20px;font-weight:700}.payment-modal__row{border-bottom:1px solid var(--color-primary-light);justify-content:space-between;align-items:baseline;gap:16px;padding:10px 0;display:flex}.payment-modal__row:last-of-type{border-bottom:none}.payment-modal__label{color:var(--color-muted);white-space:nowrap;font-size:14px;font-weight:500}.payment-modal__value{color:var(--color-text);text-align:right;word-break:break-all;font-size:14px;font-weight:600}.payment-modal__total .payment-modal__label,.payment-modal__total .payment-modal__value{color:var(--color-text);font-size:16px;font-weight:700}.payment-modal__paid{color:var(--color-success);font-size:15px;font-weight:700}.payment-modal__actions{flex-direction:column;gap:12px;margin-top:24px;display:flex}.payment-modal__actions .btn-rsvp,.payment-modal__actions .btn-secondary{margin:0}.btn-danger{color:#fff;cursor:pointer;background:#dc2626;border:none;border-radius:8px;padding:9px 18px;font-size:14px;font-weight:600;transition:background .15s}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-danger:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{color:var(--color-text);border:1px solid var(--color-muted);cursor:pointer;background:0 0;border-radius:8px;padding:9px 18px;font-size:14px;font-weight:600;transition:background .15s}.btn-secondary:hover{background:var(--color-primary-light)}.navbar__logo-link{align-items:center;display:flex}.navbar__logo-img{height:32px}.event-card__banner-img{object-fit:cover;width:100%;height:100%}.attendee-empty{color:var(--color-muted);font-size:14px}.pill-row--mb{margin-bottom:20px}.home-page .navbar{background:var(--color-bg);border-bottom:1px solid var(--color-border)}.home-page .navbar__tabs{background:var(--color-primary-light)}.home-page .navbar__tab-slider{background:var(--color-bg)}.home-page .navbar__tab:hover,.home-page .navbar__tab.active{color:var(--color-primary)}.scroll-progress{background:var(--color-primary);z-index:300;pointer-events:none;border-radius:0 3px 3px 0;height:4px;transition:width 80ms linear;position:fixed;top:0;left:0;box-shadow:0 0 8px #c0714a99}.hero{background:var(--color-text);width:100%;height:80vh;min-height:420px;position:relative;overflow:hidden}.hero__video{object-fit:cover;width:100%;height:100%;position:absolute;inset:0}.hero__fallback{background:linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-light) 50%, var(--color-bg) 100%);position:absolute;inset:0}.hero__overlay{z-index:1;text-align:center;background:#140a0573;flex-direction:column;justify-content:center;align-items:center;height:100%;padding:0 24px;display:flex;position:relative}.hero__headline{font-family:var(--font-display);color:var(--color-bg);letter-spacing:-.5px;margin-bottom:16px;font-size:clamp(2rem,5vw,3.5rem);font-weight:800;line-height:1.15}.hero__subtext{font-family:var(--font-body);color:#fdf6eed9;max-width:560px;margin-bottom:36px;font-size:clamp(1rem,2vw,1.25rem)}.hero__cta{background:var(--color-primary);color:var(--color-bg);cursor:pointer;letter-spacing:.3px;border:none;border-radius:50px;padding:16px 40px;font-size:16px;font-weight:700;transition:background .2s,transform .1s}.hero__cta:hover{background:var(--color-primary-dark)}.hero__cta:active{transform:scale(.97)}.hero__dots{gap:8px;margin-top:24px;display:flex}.hero__dot{cursor:pointer;background:#fdf6ee59;border:none;border-radius:50%;width:8px;height:8px;padding:0;transition:background .2s,transform .2s}.hero__dot--active{background:var(--color-bg);transform:scale(1.4)}.hero__dot:hover:not(.hero__dot--active){background:#fdf6eea6}.hero__scroll-hint{z-index:2;cursor:pointer;color:#fdf6eea6;background:0 0;border:none;padding:8px;transition:color .2s;animation:2s ease-in-out infinite bounce-hint;position:absolute;bottom:72px;left:50%;transform:translate(-50%)}.hero__scroll-hint:hover{color:var(--color-bg)}@keyframes bounce-hint{0%,to{transform:translate(-50%)translateY(0)}50%{transform:translate(-50%)translateY(7px)}}@media (prefers-reduced-motion:reduce){.hero__scroll-hint{animation:none}}.hero__wave{z-index:2;pointer-events:none;width:100%;height:64px;position:absolute;bottom:-1px;left:0}.home-section{background:var(--color-bg);align-items:center;min-height:320px;padding:80px 48px;display:flex;position:relative;overflow:hidden}.home-section--right{background:var(--color-bg-alt);justify-content:flex-end}.home-section--left{opacity:0;transition:transform .7s,opacity .7s;transform:translate(-60px)}.home-section--right{opacity:0;transition:transform .7s,opacity .7s;transform:translate(60px)}.home-section--visible{opacity:1;transform:translate(0)}.home-section__number{font-family:var(--font-display);color:#c0714a1a;pointer-events:none;-webkit-user-select:none;user-select:none;font-size:clamp(7rem,18vw,14rem);font-weight:800;line-height:1;position:absolute;top:50%;transform:translateY(-50%)}.home-section--left .home-section__number{right:48px}.home-section--right .home-section__number{left:48px}.home-section__content{max-width:560px}.home-section__heading{font-family:var(--font-display);color:var(--color-text);letter-spacing:-.3px;margin-bottom:16px;font-size:clamp(1.5rem,3vw,2.25rem);font-weight:800;line-height:1.2}.home-section__body{font-family:var(--font-body);color:var(--color-muted);font-size:1.0625rem;line-height:1.7}@media (width<=768px){.home-section,.home-section--right{padding:56px 24px;justify-content:flex-start!important}.home-section--left,.home-section--right{opacity:0;transform:translateY(40px)}.home-section--visible{opacity:1;transform:translateY(0)}}
