:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}body{margin:0}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;max-width:100%;min-height:100svh;margin:0 auto;display:flex}:is(body:has(.register-page) #root,body:has(.checkin-page) #root){width:100%!important;max-width:100%!important;min-height:unset!important;border-inline:none!important}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}.admin-layout{background:var(--color-bg-base);min-height:100vh;font-family:Noto Sans TC,sans-serif;display:flex}.sidebar{background:var(--color-bg-base-nav);text-align:left;flex-direction:column;flex-shrink:0;width:240px;height:100vh;display:flex;position:sticky;top:0;overflow-y:auto}.sidebar__brand{padding:24px 20px 20px}.sidebar__brand-title{color:var(--color-accent-primary);margin-bottom:4px;font-family:Noto Sans TC,sans-serif;font-size:17px;font-weight:700;line-height:1.4}.sidebar__brand-subtitle{color:var(--color-text-secondary);font-size:11px;font-weight:500;line-height:1.3}.sidebar__nav{flex:1;padding:12px 0}.sidebar__nav-icon{color:var(--color-accent-primary);flex-shrink:0}.sidebar__top-link{color:var(--color-accent-primary);align-items:center;gap:10px;padding:11px 20px;font-size:15px;font-weight:700;text-decoration:none;display:flex}.sidebar__top-link:hover{background:var(--color-accent-subtle)}.sidebar__top-link--active{background:var(--color-accent-subtle);color:var(--color-text-primary)}.sidebar__group{margin-top:4px}.sidebar__group-label{color:var(--color-accent-primary);align-items:center;gap:10px;padding:11px 20px 6px;font-size:15px;font-weight:700;display:flex}.sidebar__group-items{padding-bottom:4px}.sidebar__sub-link{color:var(--color-text-primary);padding:9px 20px 9px 50px;font-size:14px;font-weight:400;text-decoration:none;display:block}.sidebar__sub-link:hover{background:var(--color-accent-subtle)}.sidebar__sub-link--active{background:var(--color-accent-subtle);color:var(--color-accent-primary);font-weight:600}.sidebar__bottom{border-top:1px solid var(--color-border-default);padding:12px 20px}.sidebar__bottom-link{width:100%;color:var(--color-accent-primary);cursor:pointer;background:0 0;border:none;align-items:center;gap:10px;padding:9px 0;font-family:Noto Sans TC,sans-serif;font-size:15px;font-weight:700;text-decoration:none;display:flex}.sidebar__bottom-link:hover{color:var(--color-accent-hover)}.sidebar__bottom-link--active{color:var(--color-text-primary);background:var(--color-accent-subtle);border-radius:6px}.sidebar__bottom-link-icon{color:inherit}.admin-main{text-align:left;background:var(--color-bg-base);flex-direction:column;flex:1;min-width:0;display:flex}.admin-breadcrumb{color:var(--color-text-secondary);border-bottom:1px solid var(--color-border-default);background:var(--color-bg-base);padding:14px 40px;font-size:12px}.admin-breadcrumb__sep{color:var(--color-text-placeholder);margin:0 4px}.admin-breadcrumb__item{color:var(--color-text-secondary)}.admin-breadcrumb__current{color:var(--color-text-primary);font-weight:500}.admin-content{background:var(--color-bg-base);flex:1;padding:32px 40px}.login-page{background:var(--color-bg-muted);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-page__card{background:var(--color-bg-base);border:1px solid var(--color-border-default);width:320px;padding:32px}.login-page__header{text-align:center;margin-bottom:20px}.login-page__logo{object-fit:contain;width:80px;height:80px}.login-page__title{margin:10px 0 0;font-size:18px}.login-page__field{margin-bottom:12px}.login-page__label{margin-bottom:4px;font-size:14px;display:block}.login-page__input{box-sizing:border-box;border:1px solid var(--color-border-default);border-radius:4px;width:100%;margin-top:4px;padding:8px;font-size:14px}.login-page__error{color:var(--color-status-error);margin-bottom:12px;font-size:14px}.login-page__btn{cursor:pointer;background:var(--color-text-primary);width:100%;color:var(--color-text-on-dark);border:none;border-radius:4px;padding:10px;font-size:15px}.login-page__btn:disabled{opacity:.6;cursor:not-allowed}:root{--color-bg-base:#fff;--color-bg-base-nav:#f9f5fc;--color-bg-surface:#faf7f5;--color-bg-muted:#f5f0ec;--color-bg-hover:#f0ebe6;--color-bg-active:#f0ebf4;--color-border-default:#ede8e3;--color-border-strong:#d9cfc8;--color-border-muted:#f5f0ec;--color-text-primary:#1e1714;--color-text-secondary:#6b5e56;--color-text-muted:#8c7b72;--color-text-placeholder:#b8a89a;--color-text-disabled:#c8bab0;--color-text-on-dark:#fff;--color-accent-primary:#6b4c7a;--color-accent-hover:#5c3d6a;--color-accent-subtle:#f0ebf4;--color-accent-text:#6b4c7a;--color-green-primary:#06c755;--color-green-hover:#05b54c;--color-green-subtle:#e8f8ef;--color-green-text:#047a35;--color-status-success:#2e7d32;--color-status-success-bg:#e8f5e9;--color-status-warning:#e65100;--color-status-warning-bg:#fff3e0;--color-status-error:#c62828;--color-status-error-bg:#ffebee;--color-status-info:#1565c0;--color-status-info-bg:#e3f2fd;--color-btn-primary-bg:#6b4c7a;--color-btn-primary-text:#fff;--color-btn-primary-hover:#5c3d6a;--color-btn-secondary-bg:#fff;--color-btn-secondary-text:#6b4c7a;--color-btn-secondary-border:#6b4c7a;--color-btn-danger-bg:#c62828;--color-btn-danger-text:#fff;--color-btn-disabled-bg:#ede8e3;--color-btn-disabled-text:#c8bab0;--color-nav-bg:#2d1f35;--color-nav-text:#e8dff0;--color-nav-active-bg:#6b4c7a;--color-nav-active-text:#fff;--color-nav-hover-bg:#3d2a47}.btn{border:1px solid var(--color-border-default);cursor:pointer;background:var(--color-bg-base);color:var(--color-text-primary);white-space:nowrap;border-radius:8px;padding:10px 20px;font-family:Noto Sans TC,sans-serif;font-size:15px;font-weight:500;transition:background .15s,border-color .15s}.btn:hover{background:var(--color-bg-hover)}.btn--primary{background:var(--color-btn-primary-bg);color:var(--color-btn-primary-text);border-color:var(--color-btn-primary-bg)}.btn--primary:hover{background:var(--color-btn-primary-hover);border-color:var(--color-btn-primary-hover)}.btn--outline{background:var(--color-bg-base);color:var(--color-accent-primary);border-color:var(--color-accent-primary)}.btn--outline:hover{background:var(--color-accent-subtle)}.btn--sm{border-radius:6px;padding:6px 14px;font-size:13px}.btn--danger{background:var(--color-btn-danger-bg);color:var(--color-btn-danger-text);border-color:var(--color-btn-danger-bg)}.btn--disabled,.btn:disabled{background:var(--color-btn-disabled-bg);color:var(--color-btn-disabled-text);cursor:not-allowed;border-color:var(--color-btn-disabled-bg)}.btn--line{background:var(--color-green-primary);width:100%;color:var(--color-text-on-dark);cursor:pointer;border:none;border-radius:6px;padding:14px;font-size:18px;font-weight:700}.btn--line:disabled{opacity:.6;cursor:not-allowed}.btn--verify{background:var(--color-green-primary);width:100%;color:var(--color-text-on-dark);cursor:pointer;border:none;border-radius:6px;padding:12px;font-size:16px}.btn--verify:disabled{opacity:.6}.form__input{border:1px solid var(--color-border-default);box-sizing:border-box;border-radius:4px;width:100%;padding:10px 14px;font-size:15px}.form__input--readonly{background:var(--color-bg-muted);color:var(--color-text-secondary)}.form__error{color:var(--color-status-error);margin-bottom:12px}.search-box{align-items:center;display:flex;position:relative}.search-box__input{border:1px solid var(--color-border-default);color:var(--color-text-primary);background:var(--color-bg-base);border-radius:8px;outline:none;width:280px;padding:10px 14px 10px 40px;font-family:Noto Sans TC,sans-serif;font-size:15px}.search-box__input::placeholder{color:var(--color-text-secondary)}.search-box__input:focus{border-color:var(--color-accent-primary)}.search-box__icon{color:var(--color-text-secondary);pointer-events:none;align-items:center;display:flex;position:absolute;left:12px}.toolbar{justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.toolbar__bottoms{flex-direction:row;gap:12px;display:flex}.toolbar__spacer{margin-left:auto}.page-title{color:var(--color-text-primary);margin-top:0;margin-bottom:24px;font-family:Noto Sans TC,sans-serif;font-size:28px;font-weight:600}.data-table-wrap{background:var(--color-bg-base);border:1px solid var(--color-border-default);text-align:center;border-radius:8px;overflow:hidden}.data-table{border-collapse:collapse;width:100%}.data-table__head{background:var(--color-bg-base);border-bottom:1px solid var(--color-border-default)}.data-table__th{color:var(--color-text-primary);padding:12px 16px;font-family:Noto Sans TC,sans-serif;font-size:15px;font-weight:500}.data-table__th--checkbox{width:44px}.data-table__td{color:var(--color-text-primary);padding:16px;font-size:14px}.data-table__td--center{text-align:center}.data-table__td--action{text-align:right}.data-table__row{border-bottom:1px solid var(--color-border-default)}.data-table__row:last-child{border-bottom:none}.data-table__row--clickable{cursor:pointer}.data-table__row--clickable:hover{background:var(--color-bg-surface)}.data-table__empty{text-align:center;color:var(--color-text-muted);padding:40px}.table-footer{justify-content:space-between;align-items:center;padding:16px 0 0;display:flex}.table-footer__count{color:var(--color-text-secondary);font-size:13px}.pagination{align-items:center;gap:4px;display:flex}.pagination__btn{border:1px solid var(--color-border-default);background:var(--color-bg-base);min-width:36px;height:36px;color:var(--color-text-primary);cursor:pointer;border-radius:8px;padding:0 8px;font-family:Noto Sans TC,sans-serif;font-size:14px;transition:background .12s}.pagination__btn:hover:not(:disabled){background:var(--color-bg-hover)}.pagination__btn:disabled{color:var(--color-text-disabled);cursor:default}.pagination__btn--active{background:var(--color-accent-primary);color:var(--color-text-on-dark);border-color:var(--color-accent-primary);font-weight:700}.pagination__ellipsis{text-align:center;min-width:28px;color:var(--color-text-muted);font-size:14px}.simple-table{border-collapse:collapse;background:var(--color-bg-base);width:100%}.simple-table__th{border:1px solid var(--color-border-default);text-align:left;background:var(--color-bg-muted);padding:10px 12px}.simple-table__td{border:1px solid var(--color-border-default);padding:8px 12px}.simple-table__empty{text-align:center;color:var(--color-text-muted)}.spinner-wrap{justify-content:center;align-items:center;min-height:100vh;display:flex}.spinner{border:4px solid var(--color-border-default);border-top-color:var(--color-green-primary);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.page-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.page-header .page-title{margin:0}.modal-hint{color:var(--color-text-muted);margin-bottom:8px;font-size:12px}.modal-sub{color:var(--color-text-secondary);margin-bottom:8px;font-size:14px}.modal-success{color:var(--color-status-success);margin-bottom:8px}.fee-date-cell{color:var(--color-text-secondary);font-size:12px}.member-detail__section{max-width:680px;margin-top:32px}.member-detail__section-header{margin-bottom:12px}.member-detail__section-title{margin:0;font-size:15px;font-weight:700}.member-detail__joining-fee{margin-bottom:8px}.member-detail__joining-fee-label{color:var(--color-text-secondary);font-size:13px}.member-detail__actions{max-width:680px}.member-form__value{font-size:15px}.member-list__stats-card{background:var(--color-bg-base);border:1px solid var(--color-border-default);border-radius:8px;min-width:200px;margin-bottom:24px;padding:16px 20px;display:inline-block}.member-list__stats-label{color:var(--color-text-secondary);margin-bottom:4px;font-size:13px;font-weight:500}.member-list__stats-count{color:var(--color-accent-primary);font-size:30px;font-weight:600}.member-list__stats-unit{color:var(--color-text-secondary);font-size:15px;font-weight:500}.fee-page__header{align-items:center;gap:12px;margin-bottom:8px;display:flex}.fee-page__header .page-title{margin:0}.fee-setting-badge{color:var(--color-text-secondary);background:var(--color-bg-muted);border:1px solid var(--color-border-default);border-radius:6px;padding:4px 10px;font-size:13px}.fee-table th,.fee-table td{white-space:nowrap}.fee-cell{flex-direction:column;gap:2px;display:flex}.fee-cell__info,.fee-cell__amount{color:var(--color-text-muted);font-size:11px}.fee-cell--empty{color:var(--color-text-disabled);text-align:center}.fee-badge{border-radius:4px;padding:1px 6px;font-size:11px;font-weight:600;display:inline-block}.fee-badge--paid{background:var(--color-status-success-bg);color:var(--color-status-success)}.fee-badge--unpaid{background:var(--color-status-warning-bg);color:var(--color-status-warning)}.fee-link{color:var(--color-accent-primary);cursor:pointer;background:0 0;border:none;padding:0;font-size:11px;text-decoration:underline}.fee-link:hover{opacity:.7}.modal-overlay{z-index:1000;background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--color-bg-base);border-radius:12px;width:100%;min-width:340px;max-width:480px;padding:28px 32px}.modal__title{margin:0 0 20px;font-size:16px;font-weight:700}.modal__actions{justify-content:flex-end;gap:10px;margin-top:20px;display:flex}.form-group{margin-bottom:14px}.form-label{color:var(--color-text-secondary);margin-bottom:4px;font-size:13px;display:block}.form-control{box-sizing:border-box;border:1px solid var(--color-border-default);border-radius:6px;width:100%;padding:8px 10px;font-size:14px}.form-control:focus{border-color:var(--color-accent-primary);outline:none}.member-form{max-width:680px}.member-form__row{align-items:center;margin-bottom:20px;display:flex}.member-form__label{flex-shrink:0;width:120px;font-size:15px;font-weight:500}.member-form__field{flex:1}.member-form__radio{cursor:pointer;margin-right:24px;font-size:15px}.member-form__radio:last-child{margin-right:0}.member-form__radio-input{margin-right:6px}.member-form__req{color:var(--color-status-error);margin-left:2px}.member-form__error{color:var(--color-status-error);margin:12px 0}.member-form__actions{justify-content:center;gap:12px;margin-top:32px;display:flex}.member-form__btn{cursor:pointer;border:none;border-radius:4px;width:280px;padding:12px 0;font-size:15px;font-weight:500}.member-form__btn--primary{background:var(--color-text-primary);color:var(--color-text-on-dark)}.member-form__btn--secondary{background:var(--color-text-muted);color:var(--color-text-on-dark)}.event-card__meta-item{align-items:center;gap:4px;display:flex}.event-section{margin-bottom:24px}.event-section__label{color:var(--color-text-muted);margin-bottom:12px;font-size:14px}.event-section__past-header{cursor:pointer;align-items:center;gap:8px;margin-bottom:12px;display:flex}.event-section__past-arrow{color:var(--color-text-secondary);font-size:12px}.event-section__past-toggle{color:var(--color-text-on-dark);background:var(--color-text-muted);border-radius:12px;padding:2px 10px;font-size:13px}.event-list__cards{flex-direction:column;gap:12px;display:flex}.event-card{background:var(--color-bg-base);border:1px solid var(--color-border-default);border-radius:8px;align-items:center;display:flex;overflow:hidden}.event-card__photo{object-fit:cover;flex-shrink:0;width:160px;height:110px}.event-card__body{flex:1;padding:16px 20px}.event-card__code{color:var(--color-text-muted);margin-bottom:4px;font-size:12px}.event-card__title{margin-bottom:8px;font-size:20px;font-weight:700}.event-card__meta{color:var(--color-text-secondary);gap:16px;font-size:14px;display:flex}.event-card__right{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:6px;padding:16px 20px;display:flex}.event-card__count-label{color:var(--color-text-muted);font-size:12px}.event-card__count{font-size:28px;font-weight:700;line-height:1}.event-card__count-unit{margin-left:2px;font-size:14px}.past-toolbar{justify-content:flex-end;margin-bottom:8px;display:flex}.past-toolbar__year{border:1px solid var(--color-border-default);background:var(--color-bg-base);cursor:pointer;border-radius:4px;padding:6px 10px;font-size:14px}.past-table{border-collapse:collapse;background:var(--color-bg-base);border:1px solid var(--color-border-default);border-radius:8px;width:100%;overflow:hidden}.past-table th,.past-table td{text-align:left;padding:12px 16px;font-size:14px}.past-table th{background:var(--color-bg-surface);color:var(--color-text-secondary);font-weight:500}.past-table td{border-top:1px solid var(--color-bg-hover)}.past-table tr:hover td{background:var(--color-bg-surface)}.past-table td:last-child{text-align:right}.btn--sm{padding:6px 14px;font-size:13px}.event-list__empty{background:var(--color-bg-base);border:1px solid var(--color-border-default);text-align:center;color:var(--color-text-muted);border-radius:6px;padding:40px}.event-form{max-width:680px}.event-form__title{margin:0 0 8px;font-size:24px;font-weight:700}.event-form__subtitle{color:var(--color-text-secondary);margin:0 0 24px;font-size:14px}.event-form__section{background:var(--color-bg-base);border:1px solid var(--color-border-default);border-radius:8px;margin-bottom:16px;padding:24px}.event-form__section-header{align-items:center;gap:8px;margin-bottom:20px;font-size:15px;font-weight:600;display:flex}.event-form__section-num{border:1.5px solid var(--color-text-secondary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:12px;font-weight:700;display:flex}.event-form__field-group{flex-direction:column;gap:6px;margin-bottom:16px;display:flex}.event-form__field-group:last-child{margin-bottom:0}.event-form__label{color:var(--color-text-secondary);font-size:13px;font-weight:500}.event-form__row-half{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px;display:grid}.event-form__time-row{align-items:center;gap:8px;display:flex}.event-form__time-sep{color:var(--color-text-secondary);flex-shrink:0;font-size:16px}.event-form__textarea{resize:vertical;height:120px}.event-form__status-select{width:160px}.event-form__photo-area{border:1.5px dashed var(--color-border-strong);cursor:pointer;background:var(--color-bg-surface);border-radius:8px;justify-content:center;align-items:center;width:100%;min-height:140px;display:flex;overflow:hidden}.event-form__photo-area:hover{border-color:var(--color-text-muted);background:var(--color-bg-muted)}.event-form__photo-placeholder{color:var(--color-text-muted);flex-direction:column;align-items:center;gap:8px;font-size:14px;display:flex}.event-form__photo-icon{font-size:28px}.event-form__photo-preview{object-fit:cover;width:100%;max-height:240px;display:block}.event-form__option-block{border:1px solid var(--color-border-default);border-radius:6px;margin-bottom:12px;padding:12px}.event-form__option-block-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.event-form__required-toggle{color:var(--color-text-secondary);cursor:pointer;align-items:center;gap:4px;margin-left:auto;margin-right:12px;font-size:13px;display:flex}.event-form__required-toggle input{cursor:pointer}.event-form__option-inputs{grid-template-columns:1fr 1fr;gap:12px;display:grid}.event-form__delete-btn{color:var(--color-status-error);cursor:pointer;background:0 0;border:none;padding:0;font-size:13px}.event-form__delete-btn:hover{text-decoration:underline}.event-form__add-option-btn{color:var(--color-status-success);cursor:pointer;background:0 0;border:none;align-items:center;gap:4px;padding:8px 0;font-size:14px;font-weight:500;display:flex}.event-form__add-option-btn:hover{text-decoration:underline}.event-form__error{color:var(--color-status-error);margin-bottom:12px;font-size:14px}.event-form__actions{gap:12px;margin-top:8px;margin-bottom:24px;display:flex}.error-bar{margin-bottom:12px}.error-bar--top{margin-top:8px}.hidden-input{display:none}.btn--icon{align-items:center;gap:6px;display:flex}.btn--mt{margin-top:8px}.btn-icon-mr{margin-right:6px}.event-detail{padding:0 0 40px}.event-detail__header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.event-detail__title{margin:0;font-size:24px}.event-detail__body{gap:24px;margin-bottom:32px;display:flex}.event-detail__main{flex-direction:column;flex:1;gap:16px;min-width:0;display:flex}.event-detail__side{flex-direction:column;flex-shrink:0;gap:16px;width:240px;display:flex}.event-detail__section{background:var(--color-bg-base);border:1px solid var(--color-border-default);border-radius:8px;padding:16px}.event-detail__section h3{margin:0 0 12px;font-size:15px;font-weight:600}.event-detail__section-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.event-detail__section-header h3{margin:0}.event-detail__code{color:var(--color-text-secondary);background:var(--color-bg-muted);border-radius:4px;padding:2px 8px;font-size:12px}.event-detail__grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.event-detail__info-item{flex-direction:column;gap:2px;display:flex}.event-detail__info-label{color:var(--color-text-muted);font-size:11px}.event-detail__info-value{color:var(--color-text-primary);font-size:14px}.event-detail__desc{color:var(--color-text-secondary);white-space:pre-wrap;margin:0;font-size:14px;line-height:1.6}.event-detail__line-box{flex-direction:column;gap:6px;display:flex}.event-detail__line-label{font-size:13px;font-weight:500}.event-detail__line-url{color:var(--color-text-secondary);word-break:break-all;background:var(--color-bg-surface);border:1px solid var(--color-border-default);border-radius:4px;padding:8px;font-size:13px}.event-detail__photo{object-fit:cover;border-radius:6px;width:100%;margin-bottom:8px;display:block}.event-detail__photo-placeholder{background:var(--color-bg-muted);border:1px dashed var(--color-border-strong);width:100%;height:120px;color:var(--color-text-muted);border-radius:6px;justify-content:center;align-items:center;margin-bottom:8px;font-size:13px;display:flex}.event-detail__qr{justify-content:center;margin-bottom:8px;display:flex}.event-detail__qr-hint{color:var(--color-text-secondary);margin:0 0 8px;font-size:13px}.event-detail__qr-meta{color:var(--color-text-secondary);text-align:center;margin:4px 0 8px;font-size:12px}.event-detail__qr-actions{flex-wrap:wrap;gap:8px;display:flex}.event-detail__regs{background:var(--color-bg-base);border:1px solid var(--color-border-default);border-radius:8px;padding:16px}.event-detail__regs-toolbar{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:16px;display:flex}.event-detail__regs-title{margin:0;font-size:16px;font-weight:600}.event-detail__search-form{display:flex}.event-detail__search-input{width:180px}.event-detail__size-select{width:110px}.reg-attended{color:var(--color-status-success);font-weight:500}.reg-expand-btn{border:1px solid var(--color-border-strong);cursor:pointer;width:24px;height:24px;color:var(--color-text-secondary);background:0 0;border-radius:4px;justify-content:center;align-items:center;font-size:16px;line-height:1;display:flex}.reg-expand-btn:hover{background:var(--color-bg-muted)}.reg-detail-row td{background:var(--color-bg-surface);padding:12px 16px!important}.reg-detail{flex-direction:column;gap:8px;font-size:14px;display:flex}.reg-detail__row{align-items:flex-start;gap:12px;display:flex}.reg-detail__label{min-width:64px;color:var(--color-text-secondary);padding-top:2px;font-size:12px}.reg-detail__options{flex-wrap:wrap;gap:6px;display:flex}.reg-detail__option-tag{background:var(--color-status-success-bg);border:1px solid var(--color-green-subtle);color:var(--color-green-text);border-radius:12px;padding:2px 10px;font-size:13px}.reg-detail__row--total{border-top:1px solid var(--color-border-default);margin-top:4px;padding-top:8px}.reg-detail__total{color:var(--color-text-primary);font-size:16px;font-weight:700}.event-detail__pagination{color:var(--color-text-secondary);justify-content:space-between;align-items:center;margin-top:16px;font-size:13px;display:flex}.event-detail__page-btns{gap:4px;display:flex}.page-btn{border:1px solid var(--color-border-strong);background:var(--color-bg-base);cursor:pointer;min-width:32px;height:32px;color:var(--color-text-secondary);border-radius:4px;padding:0 8px;font-size:14px}.page-btn:hover:not(:disabled){background:var(--color-bg-muted)}.page-btn:disabled{opacity:.4;cursor:default}.page-btn--active{background:var(--color-status-success);color:var(--color-text-on-dark);border-color:var(--color-status-success)}.event-detail__feed-section{background:var(--color-bg-base);border:1px solid var(--color-border-default);border-radius:8px;margin-bottom:24px;overflow:hidden}.event-detail__feed-header{cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:14px 20px;display:flex}.event-detail__feed-header:hover{background:var(--color-bg-surface)}.event-detail__feed-toggle{color:var(--color-text-secondary);font-size:13px}.event-detail__feed{border-top:1px solid var(--color-border-default);max-height:300px;overflow-y:auto}.event-detail__feed-empty{text-align:center;color:var(--color-text-muted);padding:24px;font-size:14px}.event-detail__feed-item{border-bottom:1px solid var(--color-bg-muted);align-items:center;gap:12px;padding:10px 20px;font-size:14px;display:flex}.event-detail__feed-item:last-child{border-bottom:none}.event-detail__feed-time{color:var(--color-text-secondary);min-width:48px;font-size:13px}.event-detail__feed-name{flex:1;font-weight:500}.event-detail__feed-no{color:var(--color-text-muted);font-size:13px}.live-page{background:var(--color-bg-base);min-height:100vh;color:var(--color-text-primary);box-sizing:border-box;flex-direction:column;padding:24px;font-family:Noto Sans TC,sans-serif;display:flex}.live-page__header{border-bottom:1px solid var(--color-border-default);justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;display:flex}.live-page__title{color:var(--color-text-primary);font-size:24px;font-weight:700}.live-page__status{border-radius:20px;padding:4px 12px;font-size:14px}.live-page__status--on{color:var(--color-status-success);background:var(--color-status-success-bg)}.live-page__status--off{color:var(--color-text-muted);background:var(--color-bg-muted)}.live-page__error{background:var(--color-status-error-bg);color:var(--color-status-error);border-radius:6px;margin-bottom:16px;padding:10px 16px;font-size:14px}.live-page__list{flex-direction:column;flex:1;gap:8px;display:flex}.live-page__empty{text-align:center;color:var(--color-text-disabled);margin-top:80px;font-size:18px}.live-page__item{background:var(--color-bg-surface);border:1px solid var(--color-border-default);border-radius:8px;align-items:center;gap:16px;padding:16px 20px;transition:opacity .3s;display:flex}.live-page__item--new{border-color:var(--color-green-primary);background:var(--color-green-subtle);animation:.4s slideIn}@keyframes slideIn{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}.live-page__item-time{color:var(--color-text-secondary);min-width:48px;font-size:14px}.live-page__item-name{color:var(--color-text-primary);flex:1;font-size:20px;font-weight:600}.live-page__item-no{color:var(--color-text-secondary);font-size:14px}.load-error{margin-bottom:12px}.user-list__header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.user-list__title{margin:0}.user-form{background:var(--color-bg-base);border:1px solid var(--color-border-default);margin-bottom:16px;padding:16px}.user-form__title{margin-top:0}.user-form__grid{grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px;display:grid}.user-form__label{margin-bottom:4px;font-size:14px;display:block}.user-form__input{box-sizing:border-box;width:100%;padding:6px}.user-form__error{color:var(--color-status-error);margin-bottom:8px}.user-form__actions{gap:8px;display:flex}html:has(.register-page){font-size:min(2.66667vw,20px)}body:has(.register-page){background:var(--color-bg-base);margin:0}.register-page{background:var(--color-bg-base);flex-direction:column;gap:2.4rem;width:100vw;max-width:100vw;min-height:100vh;margin:0 auto;padding-top:1rem;padding-bottom:4rem;font-family:Inter,Noto Sans TC,sans-serif;display:flex;position:relative}.register-page__top-bar{background:var(--color-accent-primary);height:1rem;position:absolute;top:0;left:0;right:0}.register-page--remind{background:var(--color-bg-base);flex-direction:column;justify-content:flex-start;align-items:center;gap:2.4rem;width:100vw;padding:20rem 1.6rem 0;display:flex;position:fixed;top:0;bottom:0;left:50%;transform:translate(-50%)}.register-page--remind .not-in-line__main{width:100%}.register-page--remind .register-page__photo-wrap,.register-page--remind .register-page__title{margin:0}.register-page__photo-wrap{background-position:50%;background-repeat:no-repeat;background-size:cover;border-radius:1.2rem;flex-shrink:0;width:10rem;height:10rem;margin:4rem auto 0}.register-page__header{padding:0 1.6rem}.register-page__header--no-photo{flex-direction:column;align-items:center;gap:2.4rem;padding:3.2rem 1.6rem 0;display:flex}.register-page__title{color:var(--color-accent-primary);text-align:center;letter-spacing:.16rem;margin:0;font-size:3.2rem;font-weight:700;line-height:2.8rem}.register-page__desc{letter-spacing:.08rem;color:var(--color-text-primary);text-align:center;white-space:pre-wrap;margin:0;font-size:1.6rem;font-weight:400;line-height:2.4rem}.register-page__tags{flex-wrap:wrap;justify-content:center;gap:.8rem;display:flex}.register-page__tag{background:var(--color-accent-subtle);color:var(--color-text-primary);border-radius:5rem;align-items:center;gap:.6rem;padding:.8rem 1.6rem;font-size:1.4rem;font-weight:500;display:inline-flex}.register-page__tag-icon{font-size:1.5rem}.register-page__body{flex-direction:column;gap:2.4rem;padding:1.6rem 1.6rem 0;display:flex}.member-card{background:var(--color-bg-base);border:1px solid var(--color-border-default);border-radius:.8rem;align-items:center;gap:1.6rem;padding:1.2rem 1.6rem;display:flex}.member-card__avatar{object-fit:cover;border-radius:50%;flex-shrink:0;width:5rem;height:5rem}.member-card__info{flex-direction:column;flex:1;gap:.4rem;display:flex}.member-card__line-name{color:var(--color-text-primary);text-align:left;font-size:1.8rem;font-weight:600}.member-card__row{align-items:center;gap:1.2rem;margin-top:1rem;display:flex}.member-card__badge{color:var(--color-text-muted);font-size:1.4rem}.member-card__name{color:var(--color-text-primary);font-size:1.4rem}.section-header{align-items:center;gap:.8rem;margin-bottom:.8rem;display:flex}.section-header__bar{background:var(--color-accent-primary);border-radius:.2rem;flex-shrink:0;width:.4rem;height:2.1rem}.section-header__title{color:var(--color-text-primary);font-size:2rem;font-weight:700}.option-list{flex-direction:column;gap:0;display:flex}.option-list__item{cursor:pointer;align-items:center;gap:.8rem;padding:1.6rem 0;display:flex}.option-list__item:last-child{border-bottom:none}.option-list__item--required{cursor:default}.option-list__checkbox-wrap{flex-shrink:0;position:relative}.option-list__input{opacity:0;cursor:pointer;width:2.4rem;height:2.4rem;margin:0;position:absolute}.option-list__custom-checkbox{border:2px solid var(--color-border-default);background:var(--color-bg-base);border-radius:.4rem;justify-content:center;align-items:center;width:2.4rem;height:2.4rem;transition:background .15s,border-color .15s;display:flex}.option-list__item--checked .option-list__custom-checkbox,.option-list__item--required .option-list__custom-checkbox{background:0 0;border-color:#0000}.option-list__check-icon{justify-content:center;align-items:center;display:flex}.option-list__check-icon--svg{color:var(--color-accent-primary);display:block}.option-list__name{text-align:left;color:var(--color-text-primary);flex:1;padding-left:.8rem;font-size:1.6rem;font-weight:500}.option-list__amount{color:var(--color-accent-text);font-size:1.6rem;font-weight:700}.register-page__note{flex-direction:column;gap:0;display:flex}.register-page__textarea{background-color:var(--color-bg-base);box-sizing:border-box;border:1px solid var(--color-border-default);width:100%;height:12rem;color:var(--color-text-primary);resize:none;border-radius:.8rem;outline:none;padding:1.6rem;font-family:Noto Sans TC,sans-serif;font-size:1.4rem;box-shadow:0 .1px 3px #5a5a5a1a}.register-page__textarea::placeholder{color:var(--color-text-placeholder)}.register-page__textarea:focus{border-color:var(--color-accent-primary)}.register-page__submit-error{padding:0 20px 8px}.register-page__footer{background:var(--color-accent-hover);border-radius:.8rem;flex-direction:column;gap:2.2rem;margin-bottom:3.2rem;padding:2.4rem 1.6rem;display:flex}.amount-summary{justify-content:space-between;align-items:center;display:flex}.amount-summary__label{color:var(--color-text-on-dark);font-size:1.6rem}.amount-summary__value{color:var(--color-text-on-dark);font-size:2.4rem;font-weight:700}.btn--register{background:var(--color-btn-secondary-bg);width:100%;color:var(--color-btn-secondary-text);cursor:pointer;border:none;border-radius:.8rem;padding:1.2rem 0;font-size:1.6rem;font-weight:700}.btn--register:disabled{opacity:.6;cursor:not-allowed}.register-page--verify{background:var(--color-bg-base);flex-direction:column;justify-content:flex-start;align-items:center;width:100vw;padding:20rem 0 0;display:flex;position:fixed;top:0;bottom:0;left:50%;transform:translate(-50%)}.verify-form{flex-direction:column;align-items:center;gap:2.4rem;padding:0 1.6rem 4rem;display:flex}.verify-form__title{color:var(--color-accent-primary);text-align:center;letter-spacing:.16rem;margin:0;font-size:3.2rem;font-weight:700;line-height:2.8rem}.verify-form__desc{color:var(--color-text-primary);text-align:center;letter-spacing:.08rem;margin:0;font-size:1.6rem;font-weight:400;line-height:2.4rem}.verify-form__input{border:1px solid var(--color-border-default);box-sizing:border-box;width:34.3rem;height:4.8rem;color:var(--color-text-primary);background:var(--color-bg-base);border-radius:.8rem;outline:none;padding:1.6rem;font-size:1.4rem}.verify-form__input::placeholder{color:var(--color-text-muted)}.verify-form__input:focus{border-color:var(--color-accent-primary)}.verify-form__error{color:var(--color-status-error);text-align:center;font-size:1.6rem;line-height:2.4rem}.btn--verify{background:var(--color-accent-hover);width:34.3rem;height:4.8rem;color:var(--color-text-on-dark);cursor:pointer;border:none;border-radius:.8rem;font-size:1.6rem;font-weight:700}.btn--verify:disabled{opacity:.6;cursor:not-allowed}.register-page--registered{background:var(--color-bg-base);flex-direction:column;justify-content:flex-start;align-items:center;gap:2.4rem;width:100vw;padding:20rem 0 0;display:flex;position:fixed;top:0;bottom:0;left:50%;transform:translate(-50%)}.register-page--registered:before{content:"";background:var(--color-accent-primary);width:37.5rem;height:1rem;position:fixed;top:0;left:50%;transform:translate(-50%)}.registered-wrap__icon{background:var(--color-status-success);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:6rem;height:6rem;display:flex}.registered-wrap__icon:after{content:"✓";color:var(--color-text-on-dark);font-size:2.8rem;font-weight:700;line-height:1}.registered-wrap__title{color:var(--color-accent-primary);text-align:center;letter-spacing:.16rem;margin:0;font-size:3.2rem;font-weight:700;line-height:2.8rem}.registered-wrap__event{color:var(--color-text-primary);text-align:center;letter-spacing:.09rem;margin:0;font-size:1.8rem;font-weight:400;line-height:1.8rem}.reg-card{background:var(--color-accent-subtle);box-sizing:border-box;border-radius:.8rem;flex-direction:column;align-items:center;gap:1rem;width:34.3rem;padding:2.4rem 1.6rem;display:flex}.reg-card__label{color:var(--color-text-muted);text-align:center;letter-spacing:.08rem;font-size:1.6rem;font-weight:600}.reg-card__number{color:var(--color-accent-primary);text-align:center;letter-spacing:.16rem;font-size:3.2rem;font-weight:900;line-height:3.2rem}.not-in-line{text-align:center;color:var(--color-text-primary);flex-direction:column;flex:1;justify-content:center;align-items:center;padding:0 1.6rem;display:flex}.not-in-line__icon{display:none}.not-in-line__main{letter-spacing:.08rem;color:var(--color-text-primary);text-align:center;margin:0;font-size:1.6rem;font-weight:400;line-height:2.4rem}.not-in-line__sub{display:none}.register-page__message{text-align:center;max-width:37.5rem;margin:0 auto;padding:4.8rem 1.6rem;font-family:Noto Sans TC,sans-serif}html:has(.result-page){font-size:min(2.66667vw,20px)}body:has(.result-page){background:var(--color-bg-base);margin:0}body:has(.result-page) #root{width:100%!important;max-width:100%!important;min-height:unset!important;border-inline:none!important}.result-page{background:var(--color-bg-base);flex-direction:column;align-items:stretch;font-family:Noto Sans TC,sans-serif;display:flex;position:fixed;inset:0;overflow-y:auto}.result-page__top-bar{background:var(--color-accent-primary);flex-shrink:0;width:100%;height:1rem}.result-page__content{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2.4rem;padding:4rem 1.6rem;display:flex}.result-icon{background:var(--color-status-success);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:6rem;height:6rem;display:flex}.result-icon:after{content:"";border-left:.3rem solid var(--color-text-on-dark);border-bottom:.3rem solid var(--color-text-on-dark);width:2.6rem;height:1.4rem;display:block;transform:rotate(-45deg)translate(.1rem,-.3rem)}.result-title{color:var(--color-accent-primary);text-align:center;letter-spacing:.16rem;margin:0;font-size:3.2rem;font-weight:700;line-height:1.2}.result-event{color:var(--color-text-primary);text-align:center;letter-spacing:.09rem;margin:0;font-size:1.8rem;font-weight:400;line-height:1.8rem}.result-card{background:var(--color-accent-subtle);box-sizing:border-box;border-radius:.8rem;flex-direction:column;align-items:center;gap:1.6rem;width:34.3rem;max-width:100%;padding:2.4rem 1.6rem;display:flex;box-shadow:0 1px 3px #5a5a5a1a}.result-card__label{color:var(--color-text-muted);text-align:center;letter-spacing:.08rem;font-size:1.6rem;font-weight:600;line-height:1.6rem}.result-card__number{color:var(--color-accent-primary);text-align:center;letter-spacing:.18rem;font-size:3.6rem;font-weight:900;line-height:3.2rem}.result-card__fee-box{background:var(--color-bg-base);box-sizing:border-box;border-radius:.8rem;flex-direction:column;align-items:center;gap:1rem;width:100%;padding:1.6rem;display:flex}.result-card__fee-items{flex-direction:column;align-items:center;gap:.4rem;width:100%;display:flex}.result-card__fee-row{color:var(--color-text-primary);text-align:center;letter-spacing:.08rem;font-size:1.6rem;font-weight:400;line-height:2.4rem}.result-card__divider{background:var(--color-border-default);width:100%;height:1px}.result-card__total{color:var(--color-text-primary);text-align:center;letter-spacing:.08rem;font-size:1.6rem;font-weight:600;line-height:2.4rem}html:has(.checkin-page){font-size:min(2.66667vw,20px)}body:has(.checkin-page){background:var(--color-bg-base);margin:0}.checkin-page{background:var(--color-bg-base);flex-direction:column;justify-content:flex-start;align-items:center;gap:2.4rem;width:100vw;padding:20rem 0 0;font-family:Inter,Noto Sans TC,sans-serif;display:flex;position:fixed;top:0;bottom:0;left:50%;transform:translate(-50%)}.checkin-page:before{content:"";background:var(--color-accent-primary);width:37.5rem;height:1rem;position:fixed;top:0;left:50%;transform:translate(-50%)}.checkin-result__icon{flex-shrink:0;justify-content:center;align-items:center;width:6rem;height:6rem;animation:6s linear infinite flower-spin;display:flex}@keyframes flower-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.checkin-result__title{color:var(--color-accent-primary);text-align:center;letter-spacing:.16rem;margin:0;font-size:3.2rem;font-weight:700;line-height:2.8rem}.checkin-result__event{color:var(--color-text-primary);text-align:center;letter-spacing:.09rem;margin:0;font-size:1.8rem;font-weight:400;line-height:1.8rem}
