@charset "UTF-8";.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#3d6b1f,#4a7c59,#c9a961);padding:1rem}.login-card{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 4px 6px #0000001a;width:100%;max-width:400px}.login-card h1{color:#333;margin-bottom:.5rem;text-align:center}.login-card h2{color:#666;margin-bottom:2rem;text-align:center;font-size:1.5rem;font-weight:400}.password-login-form{margin-bottom:1.5rem}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;color:#333;font-weight:500;font-size:.9rem}.form-group input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;box-sizing:border-box;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#4a7c59}.form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.login-button{width:100%;padding:.75rem;background-color:#4a7c59;color:#fff;border:none;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s;margin-top:.5rem}.login-button:hover:not(:disabled){background-color:#3d6b1f}.login-button:disabled{opacity:.6;cursor:not-allowed}.password-login-button{margin-top:1rem}.oauth-section{margin-top:1.5rem}.oauth-divider{display:flex;align-items:center;text-align:center;margin:1.5rem 0;color:#666;font-size:.875rem}.oauth-divider:before,.oauth-divider:after{content:"";flex:1;border-bottom:1px solid #ddd}.oauth-divider span{padding:0 1rem}.oauth-buttons{display:flex;flex-direction:column;gap:.75rem}.oauth-button{width:100%;padding:.75rem;background-color:#fff;color:#333;border:1px solid #dadce0;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s,box-shadow .2s;display:flex;align-items:center;justify-content:center;gap:.75rem}.oauth-button:hover:not(:disabled){background-color:#f8f9fa;box-shadow:0 1px 3px #0000001a}.oauth-button:active:not(:disabled){background-color:#f1f3f4}.oauth-button:disabled{opacity:.6;cursor:not-allowed}.oauth-icon{flex-shrink:0}.github-button{background-color:#24292e;color:#fff;border-color:#24292e}.github-button:hover:not(:disabled){background-color:#2f363d}.mock-section{margin-top:1.5rem}.mock-login-button{background-color:#6c757d}.mock-login-button:hover:not(:disabled){background-color:#5a6268}.mock-notice{text-align:center;color:#666;font-size:.875rem;font-style:italic;margin-top:.5rem}.google-signin-container{display:flex;justify-content:center;width:100%}.google-signin-container>div{width:100%!important}.error-message{background-color:#fee;color:#c33;padding:.75rem;border-radius:4px;margin-bottom:1rem;text-align:center;font-size:.875rem}.google-login-button:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 640px){.login-container{align-items:flex-start;padding:.75rem}.login-card{margin-top:1rem;padding:1.25rem;border-radius:10px}.login-card h1{font-size:1.45rem}.login-card h2{font-size:1.15rem;margin-bottom:1.25rem}.oauth-button,.login-button{min-height:2.5rem;font-size:.95rem}}.callback-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#3d6b1f,#4a7c59,#c9a961);padding:1rem}.callback-card{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 4px 6px #0000001a;width:100%;max-width:400px;text-align:center}.callback-card h2{color:#333;margin-bottom:1rem}.callback-card p{color:#666;margin-bottom:1.5rem}.error-message{background-color:#fee;color:#c33;padding:.75rem;border-radius:4px;margin-bottom:1rem;font-size:.875rem}.back-button{padding:.75rem 1.5rem;background-color:#4a7c59;color:#fff;border:none;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s}.events-page{max-width:1200px;margin:0 auto;padding:2rem}.logout-button{padding:.5rem 1rem;background-color:#dc3545;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1rem;transition:background-color .2s}.create-button{padding:.75rem 1.5rem;background-color:#4a7c59;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1rem;font-weight:500;margin-bottom:2rem;transition:background-color .2s;height:2.5rem;line-height:1.5;box-sizing:border-box;display:inline-flex;align-items:center;justify-content:center}.admin-button{padding:.75rem 1.5rem;background-color:#c9a961;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1rem;font-weight:500;margin-bottom:2rem;transition:background-color .2s;height:2.5rem;line-height:1.5;box-sizing:border-box;display:inline-flex;align-items:center;justify-content:center}.admin-button:hover{background-color:#b8944f}.toggle-button{padding:.75rem 1.5rem;background-color:#6c757d;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1rem;font-weight:500;margin-bottom:2rem;transition:background-color .2s;height:2.5rem;line-height:1.5;box-sizing:border-box;display:inline-flex;align-items:center;justify-content:center}.toggle-button:hover{background-color:#5a6268}.toggle-button.active{background-color:#4a7c59}.toggle-button.active:hover{background-color:#3d6b1f}.export-button{padding:.75rem 1.5rem;background-color:#c9a961;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1rem;font-weight:500;margin-bottom:2rem;transition:background-color .2s}.export-button:disabled{opacity:.6;cursor:not-allowed}.events-list{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.event-card{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #2d501626;border:1px solid #e8f5e9;display:flex;flex-direction:column;gap:1rem;transition:box-shadow .2s,transform .2s}.event-card:hover{box-shadow:0 4px 8px #2d501633;transform:translateY(-2px)}.events-page .events-list .event-card .event-actions{opacity:1!important;visibility:visible!important;display:flex!important}.events-page .events-list .event-card .event-actions .action-button{opacity:1!important;visibility:visible!important}.section-title{color:#333;font-size:1.5rem;margin-top:2rem;margin-bottom:1rem}.section-title:first-of-type{margin-top:0}.inactive-events-table-container{overflow-x:auto;margin-top:1rem;margin-bottom:2rem}.inactive-events-table{width:100%;border-collapse:collapse;background:#fff;box-shadow:0 2px 4px #2d501626;border-radius:8px;overflow:hidden}.inactive-events-table thead{background-color:#4a7c59;color:#fff}.inactive-events-table th{padding:1rem;text-align:left;font-weight:600;font-size:.95rem}.inactive-events-table td{padding:1rem;border-bottom:1px solid #e8f5e9;color:#999}.inactive-events-table tbody tr:last-child td{border-bottom:none}.inactive-events-table tbody tr:hover{background-color:#f5f5f5}.inactive-row{color:#999}.table-actions{display:flex;gap:.5rem;flex-wrap:wrap}.table-actions .action-button{padding:.4rem .8rem;font-size:.85rem}.table-actions .icon-button{padding:.4rem .6rem;font-size:1.2rem;min-width:2rem;display:inline-flex;align-items:center;justify-content:center}.event-info h2{color:#333;margin-bottom:.5rem;font-size:1.5rem}.event-actions{display:flex;gap:.5rem;flex-wrap:wrap}.action-button{padding:.5rem 1rem;background-color:#3d6b1f;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1rem;transition:background-color .2s;height:2.5rem;line-height:1.5;box-sizing:border-box;display:inline-flex;align-items:center;justify-content:center}.action-button:hover{background-color:#2d5016}.action-button.delete{background-color:#dc3545}.action-button.delete:hover{background-color:#c82333}.export-modal{max-width:500px}.modal-content h3{margin-top:0;margin-bottom:1.5rem;color:#333}.form-select,.date-input{width:100%;padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem}@media (max-width: 900px){.events-page{padding:1.25rem}.page-header{flex-direction:column;align-items:flex-start;gap:.75rem}.events-list{grid-template-columns:1fr;gap:1rem}.event-card{padding:1rem}.event-info h2{font-size:1.25rem}}@media (max-width: 640px){.events-page{padding:.85rem}.page-header h1{font-size:1.6rem}.create-button,.admin-button,.toggle-button,.logout-button{width:100%;min-height:2.4rem;margin-bottom:0}.event-actions{width:100%}.event-actions .action-button{flex:1;min-width:0}.inactive-events-table th,.inactive-events-table td{padding:.55rem;font-size:.85rem}.modal-content{width:95%;padding:1rem}.modal-actions{flex-direction:column}.modal-actions .cancel-button,.modal-actions .save-button{width:100%!important;min-width:100%!important;max-width:100%!important}}.event-form-page{max-width:600px;margin:0 auto;padding:2rem}.event-form-page h1{color:#333;margin-bottom:2rem}.event-form{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 4px #0000001a}.form-group input,.form-group select{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;transition:border-color .2s}.form-group input:focus,.form-group select:focus{outline:none;border-color:#4a7c59;box-shadow:0 0 0 2px #4a7c5933}.form-group label input[type=checkbox]{width:auto;margin-right:.5rem}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.categories-section{margin-top:.5rem}.categories-list{margin-bottom:1rem;min-height:2rem}.category-item{display:flex;align-items:center;gap:.5rem;padding:.5rem;margin-bottom:.5rem;background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:4px;cursor:move;transition:background-color .2s,border-color .2s,opacity .2s,transform .2s;position:relative}.category-item:not(.editing):not([draggable=false]):hover{background-color:#e9ecef;border-color:#adb5bd}.category-item[draggable=false]{cursor:default}.category-item.dragging{opacity:.5;cursor:grabbing;transform:scale(.98)}.category-item.drag-over{border-color:#4a7c59;background-color:#e8f5e9;border-width:2px;transform:translateY(2px)}.category-item.editing{padding:0;background-color:#fff;border:1px solid #4a7c59;cursor:default}.category-item input{flex:1;padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem}.category-drag-handle{color:#6c757d;font-size:1.2rem;line-height:1;cursor:grab;-webkit-user-select:none;user-select:none;padding:.25rem;display:flex;align-items:center;letter-spacing:-.2em}.category-drag-handle:active{cursor:grabbing}.category-name{flex:1;color:#333}.edit-category-button,.remove-category-button,.save-category-button,.cancel-category-button{background:none;border:none;cursor:pointer;padding:.25rem .5rem;font-size:.9rem;opacity:.7;transition:opacity .2s}.edit-category-button:hover:not(:disabled),.remove-category-button:hover:not(:disabled),.save-category-button:hover:not(:disabled),.cancel-category-button:hover:not(:disabled){opacity:1}.edit-category-button:disabled,.remove-category-button:disabled,.save-category-button:disabled,.cancel-category-button:disabled{opacity:.4;cursor:not-allowed}.no-categories{color:#6c757d;font-style:italic;margin:.5rem 0}.add-category-form{display:flex;gap:.5rem}.add-category-form input{flex:1;padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem}.add-category-button{padding:.5rem 1rem;background-color:#667eea;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;transition:background-color .2s}.add-category-button:hover:not(:disabled){background-color:#5568d3}.add-category-button:disabled{opacity:.6;cursor:not-allowed}.react-datepicker__navigation-icon:before,.react-datepicker__year-read-view--down-arrow,.react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view--down-arrow{border-color:#ccc;border-style:solid;border-width:3px 3px 0 0;content:"";display:block;height:9px;position:absolute;top:6px;width:9px}.react-datepicker__sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip-path:inset(50%);white-space:nowrap;border:0}.react-datepicker-wrapper{display:inline-block;padding:0;border:0}.react-datepicker{font-family:Helvetica Neue,helvetica,arial,sans-serif;font-size:.8rem;background-color:#fff;color:#000;border:1px solid #aeaeae;border-radius:.3rem;display:inline-block;position:relative;line-height:initial}.react-datepicker--time-only .react-datepicker__time-container{border-left:0}.react-datepicker--time-only .react-datepicker__time,.react-datepicker--time-only .react-datepicker__time-box{border-bottom-left-radius:.375em;border-bottom-right-radius:.375em}.react-datepicker-popper{z-index:1;line-height:0}.react-datepicker-popper .react-datepicker__triangle{stroke:#aeaeae}.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle{fill:#f0f0f0;color:#f0f0f0}.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle,.react-datepicker-popper--header-middle[data-placement^=bottom] .react-datepicker__triangle,.react-datepicker-popper--header-bottom[data-placement^=bottom] .react-datepicker__triangle{fill:#fff;color:#fff}.react-datepicker-popper--header-bottom[data-placement^=top] .react-datepicker__triangle{fill:#f0f0f0;color:#f0f0f0}.react-datepicker__header{text-align:center;background-color:#f0f0f0;border-bottom:1px solid #aeaeae;border-top-left-radius:.3rem;padding:8px 0;position:relative}.react-datepicker__header--time{padding-bottom:8px;padding-left:5px;padding-right:5px}.react-datepicker__header--time:not(.react-datepicker__header--time--only){border-top-left-radius:0}.react-datepicker__header:not(.react-datepicker__header--has-time-select,.react-datepicker__header--middle,.react-datepicker__header--bottom){border-top-right-radius:.3rem}.react-datepicker__header--middle{border-top:1px solid #aeaeae;border-radius:0;margin-top:4px}.react-datepicker__header--bottom{border-bottom:none;border-top:1px solid #aeaeae;border-radius:0 0 .3rem .3rem}.react-datepicker__header-wrapper{position:relative}.react-datepicker__header-wrapper .react-datepicker__navigation--next--with-time:not(.react-datepicker__navigation--next--with-today-button){right:2px}.react-datepicker__year-dropdown-container--select,.react-datepicker__month-dropdown-container--select,.react-datepicker__month-year-dropdown-container--select,.react-datepicker__year-dropdown-container--scroll,.react-datepicker__month-dropdown-container--scroll,.react-datepicker__month-year-dropdown-container--scroll{display:inline-block;margin:0 15px}.react-datepicker__month-select,.react-datepicker__year-select,.react-datepicker__month-year-select{background-color:transparent;border:1px solid #aeaeae;border-radius:.3rem;color:inherit;cursor:pointer;font-family:inherit;font-size:inherit;margin-top:5px;padding:2px 5px}.react-datepicker__month-select:focus-visible,.react-datepicker__year-select:focus-visible,.react-datepicker__month-year-select:focus-visible{outline:auto 1px}.react-datepicker__current-month,.react-datepicker-time__header,.react-datepicker-year-header{margin-top:0;color:#000;font-weight:700;font-size:.944rem}h2.react-datepicker__current-month{padding:0;margin:0}.react-datepicker-time__header{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.react-datepicker__navigation{align-items:center;background:none;display:flex;justify-content:center;text-align:center;cursor:pointer;position:absolute;top:2px;padding:0;border:none;z-index:1;height:32px;width:32px;text-indent:-999em;overflow:hidden}.react-datepicker__navigation--previous{left:2px}.react-datepicker__navigation--next{right:2px}.react-datepicker__navigation--next--with-time:not(.react-datepicker__navigation--next--with-today-button){right:85px}.react-datepicker__navigation--years{position:relative;top:0;display:block;margin-left:auto;margin-right:auto}.react-datepicker__navigation--years-previous{top:4px}.react-datepicker__navigation--years-upcoming{top:-4px}.react-datepicker__navigation:hover *:before{border-color:#a6a6a6}.react-datepicker__navigation-icon{position:relative;top:-1px;font-size:20px;width:0}.react-datepicker__navigation-icon--next{left:-2px}.react-datepicker__navigation-icon--next:before{transform:rotate(45deg);left:-7px}.react-datepicker__navigation-icon--previous{right:-2px}.react-datepicker__navigation-icon--previous:before{transform:rotate(225deg);right:-7px}.react-datepicker__month-container{float:left}.react-datepicker__year{margin:.5em;text-align:center}.react-datepicker__year-wrapper{display:flex;flex-wrap:wrap;max-width:180px}.react-datepicker__year .react-datepicker__year-text{display:inline-block;width:5em;margin:2px}.react-datepicker__month{margin:.5em;text-align:center}.react-datepicker__month .react-datepicker__month-text,.react-datepicker__month .react-datepicker__quarter-text{display:inline-block;width:5em;margin:2px}.react-datepicker__input-time-container{clear:both;width:100%;float:left;margin:5px 0 10px 15px;text-align:left}.react-datepicker__input-time-container .react-datepicker-time__caption,.react-datepicker__input-time-container .react-datepicker-time__input-container{display:inline-block}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input{display:inline-block;margin-left:10px}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input{width:auto}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]::-webkit-inner-spin-button,.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]{-moz-appearance:textfield}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__delimiter{margin-left:5px;display:inline-block}.react-datepicker__time-container{float:right;border-left:1px solid #aeaeae;width:85px}.react-datepicker__time-container--with-today-button{display:inline;border:1px solid #aeaeae;border-radius:.375em;position:absolute;right:-87px;top:0}.react-datepicker__time-container .react-datepicker__time{position:relative;background:#fff;border-bottom-right-radius:.375em}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box{width:85px;overflow-x:hidden;margin:0 auto;text-align:center;border-bottom-right-radius:.375em}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list{list-style:none;margin:0;height:calc(195px + 1.0625em);overflow-y:scroll;padding-right:0;padding-left:0;width:100%;box-sizing:content-box}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item{height:30px;padding:5px 10px;white-space:nowrap}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item:hover{cursor:pointer;background-color:#f0f0f0}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--selected{background-color:#216ba5;color:#fff;font-weight:700}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--selected:hover{background-color:#216ba5}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--disabled{color:#ccc}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--disabled:hover{cursor:default;background-color:transparent}.react-datepicker__week-number{color:#ccc;display:inline-block;width:2.125em;line-height:2.125em;text-align:center;margin:.208em}.react-datepicker__week-number.react-datepicker__week-number--clickable{cursor:pointer}.react-datepicker__week-number.react-datepicker__week-number--clickable:not(.react-datepicker__week-number--selected):hover{border-radius:.3rem;background-color:#f0f0f0}.react-datepicker__week-number--selected{border-radius:.3rem;background-color:#216ba5;color:#fff}.react-datepicker__week-number--selected:hover{background-color:#1d5d90}.react-datepicker__day-names{text-align:center;white-space:nowrap;margin-bottom:-8px}.react-datepicker__week{white-space:nowrap}.react-datepicker__day-name,.react-datepicker__day,.react-datepicker__time-name{color:#000;display:inline-block;width:2.125em;line-height:2.125em;text-align:center;margin:.208em}.react-datepicker__day-name--disabled,.react-datepicker__day--disabled,.react-datepicker__time-name--disabled{cursor:default;color:#ccc}.react-datepicker__day,.react-datepicker__month-text,.react-datepicker__quarter-text,.react-datepicker__year-text{cursor:pointer}.react-datepicker__day:not([aria-disabled=true]):hover,.react-datepicker__month-text:not([aria-disabled=true]):hover,.react-datepicker__quarter-text:not([aria-disabled=true]):hover,.react-datepicker__year-text:not([aria-disabled=true]):hover{border-radius:.3rem;background-color:#f0f0f0}.react-datepicker__day--today,.react-datepicker__month-text--today,.react-datepicker__quarter-text--today,.react-datepicker__year-text--today{font-weight:700}.react-datepicker__day--highlighted,.react-datepicker__month-text--highlighted,.react-datepicker__quarter-text--highlighted,.react-datepicker__year-text--highlighted{border-radius:.3rem;background-color:#3dcc4a;color:#fff}.react-datepicker__day--highlighted:not([aria-disabled=true]):hover,.react-datepicker__month-text--highlighted:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--highlighted:not([aria-disabled=true]):hover,.react-datepicker__year-text--highlighted:not([aria-disabled=true]):hover{background-color:#32be3f}.react-datepicker__day--highlighted-custom-1,.react-datepicker__month-text--highlighted-custom-1,.react-datepicker__quarter-text--highlighted-custom-1,.react-datepicker__year-text--highlighted-custom-1{color:#f0f}.react-datepicker__day--highlighted-custom-2,.react-datepicker__month-text--highlighted-custom-2,.react-datepicker__quarter-text--highlighted-custom-2,.react-datepicker__year-text--highlighted-custom-2{color:green}.react-datepicker__day--holidays,.react-datepicker__month-text--holidays,.react-datepicker__quarter-text--holidays,.react-datepicker__year-text--holidays{position:relative;border-radius:.3rem;background-color:#ff6803;color:#fff}.react-datepicker__day--holidays .overlay,.react-datepicker__month-text--holidays .overlay,.react-datepicker__quarter-text--holidays .overlay,.react-datepicker__year-text--holidays .overlay{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background-color:#333;color:#fff;padding:4px;border-radius:4px;white-space:nowrap;visibility:hidden;opacity:0;transition:visibility 0s,opacity .3s ease-in-out}.react-datepicker__day--holidays:not([aria-disabled=true]):hover,.react-datepicker__month-text--holidays:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--holidays:not([aria-disabled=true]):hover,.react-datepicker__year-text--holidays:not([aria-disabled=true]):hover{background-color:#cf5300}.react-datepicker__day--holidays:hover .overlay,.react-datepicker__month-text--holidays:hover .overlay,.react-datepicker__quarter-text--holidays:hover .overlay,.react-datepicker__year-text--holidays:hover .overlay{visibility:visible;opacity:1}.react-datepicker__day--selected,.react-datepicker__day--in-selecting-range,.react-datepicker__day--in-range,.react-datepicker__month-text--selected,.react-datepicker__month-text--in-selecting-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--selected,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--selected,.react-datepicker__year-text--in-selecting-range,.react-datepicker__year-text--in-range{border-radius:.3rem;background-color:#216ba5;color:#fff}.react-datepicker__day--selected:not([aria-disabled=true]):hover,.react-datepicker__day--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__day--in-range:not([aria-disabled=true]):hover,.react-datepicker__month-text--selected:not([aria-disabled=true]):hover,.react-datepicker__month-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__month-text--in-range:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--selected:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--in-range:not([aria-disabled=true]):hover,.react-datepicker__year-text--selected:not([aria-disabled=true]):hover,.react-datepicker__year-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__year-text--in-range:not([aria-disabled=true]):hover{background-color:#1d5d90}.react-datepicker__day--keyboard-selected,.react-datepicker__month-text--keyboard-selected,.react-datepicker__quarter-text--keyboard-selected,.react-datepicker__year-text--keyboard-selected{border-radius:.3rem;background-color:#bad9f1;color:#000}.react-datepicker__day--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__month-text--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__year-text--keyboard-selected:not([aria-disabled=true]):hover{background-color:#1d5d90;color:#fff}.react-datepicker__day--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__month-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__quarter-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__year-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range){background-color:#216ba580}.react-datepicker__month--selecting-range .react-datepicker__day--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__day--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__month-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__month-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__quarter-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__quarter-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__year-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__year-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range){background-color:#f0f0f0;color:#000}.react-datepicker__day--disabled,.react-datepicker__month-text--disabled,.react-datepicker__quarter-text--disabled,.react-datepicker__year-text--disabled{cursor:default;color:#ccc}.react-datepicker__day--disabled .overlay,.react-datepicker__month-text--disabled .overlay,.react-datepicker__quarter-text--disabled .overlay,.react-datepicker__year-text--disabled .overlay{position:absolute;bottom:70%;left:50%;transform:translate(-50%);background-color:#333;color:#fff;padding:4px;border-radius:4px;white-space:nowrap;visibility:hidden;opacity:0;transition:visibility 0s,opacity .3s ease-in-out}.react-datepicker__input-container{position:relative;display:inline-block;width:100%}.react-datepicker__input-container .react-datepicker__calendar-icon{position:absolute;padding:.625em;box-sizing:content-box}.react-datepicker__view-calendar-icon input{padding:6px 10px 5px 25px}.react-datepicker__year-read-view,.react-datepicker__month-read-view,.react-datepicker__month-year-read-view{border:1px solid transparent;border-radius:.3rem;position:relative}.react-datepicker__year-read-view:hover,.react-datepicker__month-read-view:hover,.react-datepicker__month-year-read-view:hover{cursor:pointer}.react-datepicker__year-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__year-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__month-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__month-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__month-year-read-view:hover .react-datepicker__month-read-view--down-arrow{border-top-color:#b3b3b3}.react-datepicker__year-read-view--down-arrow,.react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view--down-arrow{transform:rotate(135deg);right:-16px;top:0}.react-datepicker__year-dropdown,.react-datepicker__month-dropdown,.react-datepicker__month-year-dropdown{background-color:#f0f0f0;position:absolute;width:50%;left:25%;top:30px;z-index:1;text-align:center;border-radius:.3rem;border:1px solid #aeaeae}.react-datepicker__year-dropdown:hover,.react-datepicker__month-dropdown:hover,.react-datepicker__month-year-dropdown:hover{cursor:pointer}.react-datepicker__year-dropdown--scrollable,.react-datepicker__month-dropdown--scrollable,.react-datepicker__month-year-dropdown--scrollable{height:150px;overflow-y:scroll}.react-datepicker__year-option,.react-datepicker__month-option,.react-datepicker__month-year-option{line-height:20px;width:100%;display:block;margin-left:auto;margin-right:auto}.react-datepicker__year-option:first-of-type,.react-datepicker__month-option:first-of-type,.react-datepicker__month-year-option:first-of-type{border-top-left-radius:.3rem;border-top-right-radius:.3rem}.react-datepicker__year-option:last-of-type,.react-datepicker__month-option:last-of-type,.react-datepicker__month-year-option:last-of-type{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;border-bottom-left-radius:.3rem;border-bottom-right-radius:.3rem}.react-datepicker__year-option:hover,.react-datepicker__month-option:hover,.react-datepicker__month-year-option:hover{background-color:#ccc}.react-datepicker__year-option:hover .react-datepicker__navigation--years-upcoming,.react-datepicker__month-option:hover .react-datepicker__navigation--years-upcoming,.react-datepicker__month-year-option:hover .react-datepicker__navigation--years-upcoming{border-bottom-color:#b3b3b3}.react-datepicker__year-option:hover .react-datepicker__navigation--years-previous,.react-datepicker__month-option:hover .react-datepicker__navigation--years-previous,.react-datepicker__month-year-option:hover .react-datepicker__navigation--years-previous{border-top-color:#b3b3b3}.react-datepicker__year-option--selected,.react-datepicker__month-option--selected,.react-datepicker__month-year-option--selected{position:absolute;left:15px}.react-datepicker__close-icon{cursor:pointer;background-color:transparent;border:0;outline:0;padding:0 6px 0 0;position:absolute;top:0;right:0;height:100%;display:table-cell;vertical-align:middle}.react-datepicker__close-icon:after{cursor:pointer;background-color:#216ba5;color:#fff;border-radius:50%;height:16px;width:16px;padding:2px;font-size:12px;line-height:1;text-align:center;display:table-cell;vertical-align:middle;content:"×"}.react-datepicker__close-icon--disabled{cursor:default}.react-datepicker__close-icon--disabled:after{cursor:default;background-color:#ccc}.react-datepicker__today-button{background:#f0f0f0;border-top:1px solid #aeaeae;cursor:pointer;text-align:center;font-weight:700;padding:5px 0;clear:left}.react-datepicker__portal{position:fixed;width:100vw;height:100vh;background-color:#000c;left:0;top:0;justify-content:center;align-items:center;display:flex;z-index:2147483647}.react-datepicker__children-container{width:17.25em;margin:.5em;padding-right:.25em;padding-left:.25em;height:auto}.react-datepicker__aria-live{position:absolute;clip-path:circle(0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;width:1px;white-space:nowrap}.react-datepicker__calendar-icon{width:1em;height:1em;vertical-align:-.125em}.react-datepicker-popper-offset{margin-top:-.7em}.timeslot-form-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;padding:1rem}.timeslot-form-card{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 4px 6px #0003;width:100%;max-width:600px;max-height:90vh;overflow-y:auto}.timeslot-form-card h2{color:#333;margin-bottom:1.5rem}.timeslot-form{display:flex;flex-direction:column}.form-group input,.form-group textarea,.date-picker-input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;font-family:inherit;transition:border-color .2s}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#4a7c59;box-shadow:0 0 0 2px #4a7c5933}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1rem}.cancel-button{padding:.75rem 1.5rem;background-color:#6c757d;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1rem;transition:background-color .2s}.cancel-button:disabled{opacity:.6;cursor:not-allowed}.submit-button{padding:.75rem 1.5rem;background-color:#4a7c59;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1rem;font-weight:500;transition:background-color .2s}.submit-button:hover:not(:disabled){background-color:#3d6b1f}.submit-button:disabled{opacity:.6;cursor:not-allowed}.delete-button{padding:.75rem 1.5rem;background-color:#dc3545;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1rem;transition:background-color .2s}.delete-button:hover:not(:disabled){background-color:#c82333}.delete-button:disabled{opacity:.6;cursor:not-allowed}.copy-button{padding:.75rem 1.5rem;background-color:#17a2b8;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1rem;transition:background-color .2s}.copy-button:hover:not(:disabled){background-color:#138496}.copy-button:disabled{opacity:.6;cursor:not-allowed}.form-actions .delete-button,.form-actions .cancel-button,.form-actions .copy-button,.form-actions .submit-button{min-width:120px;height:2.4rem;padding:.55rem 1rem;font-size:.95rem;box-sizing:border-box;display:inline-flex;align-items:center;justify-content:center}@media (max-width: 640px){.form-row{grid-template-columns:1fr}}.event-detail-page{width:100%;max-width:1400px;margin:0 auto;padding:clamp(.35rem,1.5vw,2rem);box-sizing:border-box}.back-button{padding:.5rem 1rem;background-color:#6c757d;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1rem;margin-bottom:1rem;transition:background-color .2s}.back-button:hover{background-color:#5a6268}.page-header h1{color:#333;margin-bottom:2rem;font-size:2rem}.event-info{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #2d501626;border:1px solid #e8f5e9;margin-bottom:2rem}.event-info-top{display:flex;gap:2rem;align-items:flex-start}.event-info-left{flex:1}.event-info p{color:#666;margin-bottom:.5rem}.event-actions{margin-top:1rem;display:flex;gap:.75rem;flex-wrap:wrap}.event-statistics{min-width:250px;background:#f8f9fa;padding:1rem;border-radius:6px;border:1px solid #dee2e6}.statistics-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.event-statistics h4{margin:0;color:#333;font-size:1rem;font-weight:600}.statistics-link{background:none;border:none;color:#4a7c59;cursor:pointer;font-size:.9rem;text-decoration:underline;padding:0;transition:color .2s}.statistics-link:hover{color:#3d6b1f}.statistics-grid{display:flex;flex-direction:column;gap:.5rem}.stat-item{display:flex;justify-content:space-between;align-items:center;font-size:.9rem}.stat-label{color:#666;margin-right:.5rem}.stat-value{color:#333;font-weight:600}.edit-button,.create-timeslot-button,.export-button,.public-signup-link{padding:.5rem 1rem;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1rem;line-height:1.5;transition:background-color .2s;height:2.5rem;box-sizing:border-box;display:inline-flex;align-items:center;justify-content:center}.edit-button{background-color:#3d6b1f}.edit-button:hover{background-color:#2d5016}.create-timeslot-button{background-color:#4a7c59}.create-timeslot-button:hover{background-color:#3d6b1f}.public-signup-link{background-color:#c9a961;text-decoration:none}.public-signup-link:hover{background-color:#b8944f}.export-button{background-color:#c9a961}.export-button:hover{background-color:#b8944f}.export-button:hover{background-color:#138496}.statistics-modal{max-width:800px;width:90%;max-height:85vh;display:flex;flex-direction:column}.statistics-modal .modal-description{margin-bottom:1rem}.statistics-modal .modal-actions{margin-top:1rem}.statistics-chart{margin:1.5rem 0;overflow:visible}.statistics-svg{display:block;margin:0 auto;max-width:100%;height:auto}.statistics-detail-modal{max-width:500px}.statistics-detail-content{margin:1.5rem 0}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-bottom:1px solid #e9ecef}.detail-row:last-child{border-bottom:none}.detail-row-full{flex-direction:column;align-items:flex-start;gap:.5rem}.detail-row strong{color:#333;font-weight:600;min-width:150px}.detail-row span{color:#666;text-align:right}.timeslot-names-list{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.25rem}.timeslot-name-badge{background-color:#e9ecef;color:#495057;padding:.25rem .75rem;border-radius:12px;font-size:.875rem}.staffing-button{padding:.5rem 1rem;background-color:#28a745;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1rem;transition:background-color .2s}.staffing-button:hover{background-color:#218838}.staffing-section{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #2d501626;border:1px solid #e8f5e9}.staffing-section h2{color:#333;margin-bottom:1.5rem;font-size:1.5rem}.staffing-filters{background:#f8f9fa;padding:1rem 1.5rem;border-radius:8px;margin-bottom:2rem;display:flex;justify-content:space-between;align-items:center;gap:1.5rem;flex-wrap:wrap}.staffing-filters-left{display:flex;gap:1.5rem;flex-wrap:wrap}.staffing-filters label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:1rem;color:#333}.staffing-filters input[type=checkbox]{width:auto;cursor:pointer}.staffing-search{display:flex;align-items:center;gap:.5rem;position:relative}.search-input{padding:.5rem 2rem .5rem .75rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem;min-width:250px}.search-input:focus{outline:none;border-color:#4a7c59;box-shadow:0 0 0 2px #4a7c591a}.search-clear-button{position:absolute;right:.5rem;background:none;border:none;color:#666;cursor:pointer;font-size:1rem;padding:.25rem;line-height:1;display:flex;align-items:center;justify-content:center;transition:color .2s}.search-clear-button:hover{color:#333}.staffing-table-container{background:#f0f0f0;border-radius:8px;overflow-x:auto}.staffing-table{table-layout:fixed;width:100%;border-collapse:collapse;background-color:#f0f0f0}.staffing-table th,.staffing-table td{border:none}.staffing-table th:nth-child(1),.staffing-table td:nth-child(1){width:24%;min-width:8rem}.staffing-table th:nth-child(2),.staffing-table td:nth-child(2){width:11%;min-width:9.5rem;box-sizing:border-box}.staffing-table th:nth-child(3),.staffing-table td:nth-child(3){width:13%;min-width:11rem;box-sizing:border-box}.staffing-table th:nth-child(4),.staffing-table td:nth-child(4){width:8%;min-width:3.25rem;padding-left:.35rem;padding-right:.75rem;box-sizing:border-box}.staffing-table th:nth-child(5),.staffing-table td:nth-child(5){width:auto;min-width:0}.staffing-table thead{background-color:#f8f9fa}.staffing-table tbody{background-color:#f0f0f0}.staffing-table thead th{padding:1rem;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #dee2e6}.staffing-table td{padding:.75rem 1rem;color:#666;vertical-align:middle}.staffing-table tbody tr:not(.category-header-row):not(.booked-timeslot){background-color:#f0f0f0}.staffing-table tbody tr:not(.category-header-row):not(.booked-timeslot) td:nth-child(2),.staffing-table tbody tr:not(.category-header-row):not(.booked-timeslot) td:nth-child(3),.staffing-table tbody tr:not(.category-header-row):not(.booked-timeslot) td:nth-child(4){background-color:#f0f0f0}.staffing-table td:nth-child(2),.staffing-table td:nth-child(3){white-space:normal;overflow-wrap:break-word;word-break:normal}.staffing-table th:nth-child(3),.staffing-table td:nth-child(3){padding-right:.35rem}.staffing-table th:nth-child(4),.staffing-table td:nth-child(4){padding-left:.35rem}.staffing-table td:nth-child(4){white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.staffing-table tbody tr{height:auto;min-height:3rem}.staffing-table tbody tr:not(.category-header-row):not(.booked-timeslot):hover{background-color:#f0f0f0}.category-header-row{background-color:#e9ecef}.category-header-row td{background-color:#e9ecef;font-weight:600;font-size:1.1rem;color:#495057;padding:.75rem 1rem!important;border-top:1px solid #d0d0d0;border-bottom:1px solid #d0d0d0;text-align:left}.category-header-content{display:flex;justify-content:space-between;align-items:center;width:100%;background-color:var(--category-color, #e9ecef);border-radius:6px;padding:.35rem .5rem}.category-header-name{font-size:1.1rem}.category-header-date{font-size:.9rem;color:#6c757d}.staffing-table .group-name{font-weight:600;color:#333;background-color:#f0f0f0;vertical-align:top;white-space:normal;word-break:break-word}.staffing-table .group-name.category-colored-name{background-color:var(--category-color, #f0f0f0)}.group-name-container{display:flex;align-items:center;gap:.5rem}.timeslot-name-block{display:flex;flex-direction:column;align-items:flex-start;gap:.1rem}.change-group-date-button{background:none;border:none;cursor:pointer;padding:.25rem;font-size:1rem;opacity:.6;transition:opacity .2s;display:flex;align-items:center;justify-content:center}.change-group-date-button:hover{opacity:1}.change-group-date-button:active{transform:scale(.95)}.timeslot-name-text{font-weight:600;color:#333;white-space:normal;word-break:break-word}.timeslot-category-text{font-size:.78rem;color:#6c757d;font-weight:400;line-height:1.2}.code-cell-container{display:flex;align-items:center;gap:.5rem;justify-content:space-between}.timeslot-action-buttons{display:flex;align-items:center;gap:.25rem}.edit-timeslot-button,.copy-timeslot-button{background:none;border:none;cursor:pointer;padding:.25rem;font-size:1rem;opacity:.6;transition:opacity .2s;display:flex;align-items:center;justify-content:center}.edit-timeslot-button:hover,.copy-timeslot-button:hover{opacity:1}.edit-timeslot-button:active,.copy-timeslot-button:active{transform:scale(.95)}.description-tooltip-wrapper{position:relative;display:inline-flex;align-items:center}.description-tooltip{display:inline-flex;align-items:center;justify-content:center;width:1.2rem;height:1.2rem;border-radius:50%;background-color:#7b8794;color:#fff;font-size:.75rem;font-weight:700;cursor:help;line-height:1;border:1px solid rgba(255,255,255,.65);padding:0;transition:background-color .2s,transform .2s}.description-tooltip:hover{background-color:#5f6b78;transform:translateY(-1px)}.description-tooltip-bubble{position:absolute;z-index:20;left:calc(100% + .5rem);top:50%;transform:translateY(-50%);min-width:220px;max-width:360px;padding:.65rem .8rem;border-radius:8px;border:1px solid #dbe5de;background:#fbfdf9;color:#2f3b32;font-size:.82rem;font-weight:400;line-height:1.4;white-space:pre-wrap;box-shadow:0 8px 18px #233e2b24;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .16s ease,visibility .16s ease}.description-tooltip-bubble:before{content:"";position:absolute;left:-6px;top:50%;width:10px;height:10px;background:#fbfdf9;border-left:1px solid #dbe5de;border-bottom:1px solid #dbe5de;transform:translateY(-50%) rotate(45deg)}.description-tooltip-wrapper:hover .description-tooltip-bubble,.description-tooltip-wrapper:focus-within .description-tooltip-bubble{opacity:1;visibility:visible}@media (max-width: 900px){.description-tooltip-bubble{left:0;top:calc(100% + .5rem);transform:none;max-width:min(320px,80vw)}.description-tooltip-bubble:before{left:10px;top:-6px;transform:rotate(45deg);border-left:1px solid #dbe5de;border-bottom:none;border-top:1px solid #dbe5de}}.staffing-table .no-data{text-align:center;color:#999;padding:2rem;font-style:italic}.staffing-cell{position:relative;display:flex;flex-direction:row;align-items:center;gap:.5rem;flex-wrap:wrap;min-height:2.5rem;width:100%;box-sizing:border-box}.staffing-names{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;flex:1 1 auto;min-width:0;min-height:2rem}.staffing-names .participant-name-link,.staffing-names span:not(.no-participants){flex:1 1 0;min-width:80px;text-align:center;padding:.25rem .5rem;border-radius:4px;background-color:#fff3;display:inline-block;box-sizing:border-box;height:2rem;line-height:1.5rem;display:inline-flex;align-items:center;justify-content:center}.staffing-cell.staffing-empty .staffing-names .participant-name-link,.staffing-cell.staffing-empty .staffing-names span:not(.no-participants){background-color:#fff9}.staffing-cell.staffing-above .staffing-names .participant-name-link,.staffing-cell.staffing-above .staffing-names span:not(.no-participants){background-color:#ffffff4d}.staffing-cell.staffing-below .staffing-names .participant-name-link,.staffing-cell.staffing-exact .staffing-names .participant-name-link,.staffing-cell.staffing-below .staffing-names span:not(.no-participants),.staffing-cell.staffing-exact .staffing-names span:not(.no-participants){background-color:#0000000d}.staffing-names .no-participants{flex:none;background:none;padding:0}.staffing-names .empty-slot{flex:1 1 0;min-width:80px;text-align:center;padding:.25rem .5rem;border-radius:4px;background-color:#ffffff4d;display:inline-flex;align-items:center;justify-content:center;color:#999;border:1px dashed rgba(0,0,0,.2);height:2rem;line-height:1.5rem;box-sizing:border-box}.staffing-cell.staffing-empty .empty-slot{background-color:#ffffff80;border-color:#721c244d}.staffing-cell.staffing-below .empty-slot{background-color:#fff6;border-color:#721c244d}.staffing-cell.staffing-exact .empty-slot,.staffing-cell.staffing-above .empty-slot{background-color:#fff3;border-color:#0003}.participant-name-link{background:none;border:none;cursor:pointer;text-decoration:underline;padding:0;font-size:inherit;font-family:inherit;white-space:nowrap}.staffing-cell.staffing-empty .participant-name-link{color:#721c24}.staffing-cell.staffing-empty .participant-name-link:hover{color:#5a1a1f}.staffing-cell.staffing-above .participant-name-link{color:#fff}.staffing-cell.staffing-above .participant-name-link:hover{color:#e0e0e0}.staffing-cell.staffing-below .participant-name-link,.staffing-cell.staffing-exact .participant-name-link{color:#2d5016}.staffing-cell.staffing-below .participant-name-link:hover,.staffing-cell.staffing-exact .participant-name-link:hover{color:#1b5e20}.staffing-cell:not(.staffing-empty):not(.staffing-below):not(.staffing-exact):not(.staffing-above) .participant-name-link{color:#2d5016}.staffing-cell:not(.staffing-empty):not(.staffing-below):not(.staffing-exact):not(.staffing-above) .participant-name-link:hover{color:#1b5e20}.no-participants{color:#999}.staffing-cell.staffing-empty .no-participants{color:#721c24}.add-participant-button{padding:.25rem .5rem;background-color:#4a7c59;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.875rem;transition:background-color .2s;flex-shrink:0;height:2rem;box-sizing:border-box;display:inline-flex;align-items:center;justify-content:center}.add-participant-button:hover{background-color:#3d6b1f}.staffing-cell.staffing-empty{background-color:#f2b3b8;color:#721c24}.staffing-cell.staffing-below{background-color:#f8d7da;color:#721c24}.staffing-cell.staffing-exact{background-color:#a5d6a7;color:#1b5e20}.staffing-cell.staffing-above{background-color:#81c784;color:#1b5e20}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.email-dialog-overlay{z-index:1001}.modal-content{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 4px 6px #0000001a;max-width:500px;width:90%}.modal-content h3{margin-top:0;margin-bottom:1rem;color:#333}.modal-description{color:#666;margin-bottom:1.5rem;font-size:.9rem}.modal-content .form-group{margin-bottom:1.5rem}.modal-content .form-group label{display:block;margin-bottom:.5rem;color:#333;font-weight:500}.modal-content .date-input,.modal-content .form-select,.modal-content .form-input{width:100%;padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.modal-actions{display:flex;gap:1rem;justify-content:flex-end}.modal-actions .cancel-button,.modal-actions .save-button{padding:.5rem 1rem!important;border:none;border-radius:4px;cursor:pointer;font-size:1rem;transition:background-color .2s;width:140px!important;min-width:140px!important;max-width:140px!important;height:2.5rem!important;box-sizing:border-box!important;display:inline-flex!important;align-items:center;justify-content:center;flex-shrink:0!important;flex-grow:0!important}.modal-actions .cancel-button{background-color:#6c757d;color:#fff}.modal-actions .cancel-button:hover:not(:disabled){background-color:#5a6268}.modal-actions .save-button{background-color:#4a7c59;color:#fff}.modal-actions .save-button:hover:not(:disabled){background-color:#3d6b1f}.modal-actions .cancel-button:disabled,.modal-actions .save-button:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.event-detail-page{padding:clamp(.35rem,2vw,1rem)}.page-header h1{font-size:1.5rem;margin-bottom:1rem}.event-info,.staffing-section{padding:1rem}.event-info-top{flex-direction:column;gap:1rem}.event-actions{width:100%;gap:.5rem}.event-actions .edit-button,.event-actions .create-timeslot-button,.event-actions .export-button,.event-actions .public-signup-link{width:100%}.event-statistics{min-width:auto;width:100%}.staffing-filters{padding:.85rem;gap:.85rem}.staffing-filters-left{width:100%;gap:.8rem}.staffing-search{width:100%}.search-input{width:100%;min-width:0}.staffing-table-container{font-size:.875rem}.staffing-table{min-width:0}.staffing-table th,.staffing-table td{padding:.5rem}.modal-content{padding:1.5rem}.modal-actions{flex-wrap:wrap}}@media (max-width: 480px){.event-detail-page{padding:clamp(.25rem,1.5vw,.75rem)}.page-header h1{font-size:1.35rem}.staffing-section h2{font-size:1.2rem}.staffing-filters label{font-size:.92rem}.modal-content{width:95%;padding:1rem}.modal-actions{flex-direction:column}.modal-actions .cancel-button,.modal-actions .save-button{width:100%!important;min-width:100%!important;max-width:100%!important}}.public-timeslots-page{max-width:1200px;margin:0 auto;padding:2rem}.password-form-container{max-width:400px;margin:4rem auto;background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 4px #0000001a}.password-form-container h1{color:#333;margin-bottom:2rem;text-align:center}.password-form{display:flex;flex-direction:column}.form-group input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#667eea}.submit-button{width:100%;padding:.75rem;background-color:#667eea;color:#fff;border:none;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s}.submit-button:hover{background-color:#5568d3}.event-header{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:2rem}.event-header h1{color:#333;margin-bottom:1rem}.event-header p{color:#666}.timeslots-container{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 4px #0000001a}.timeslots-container h2{color:#333;margin-bottom:1.5rem}.timeslots-grid{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.public-timeslot-item{background:#f8f9fa;padding:1.5rem;border-radius:8px;border:1px solid #dee2e6}.public-timeslot-item h3{color:#333;margin-bottom:.5rem;font-size:1.25rem}.public-timeslot-item p{color:#666;margin-bottom:.5rem}.public-signup-page{width:100%;max-width:min(1400px,100%);margin:0 auto;padding:clamp(.35rem,1.5vw,2rem);box-sizing:border-box}.password-form-container{max-width:400px;margin:4rem auto;padding:2rem;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a}.password-form{display:flex;flex-direction:column;gap:1rem}.event-header{margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid #e0e0e0}.event-header h1{margin:0 0 .5rem;color:#333}.event-header p{margin:.5rem 0;color:#666}.timeslot-name-text{font-weight:600;color:#333}.signup-form-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.signup-form-card{background:#fff;border-radius:8px;padding:2rem;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 4px 16px #0003}.signup-form-card h2{margin:0 0 1.5rem;color:#333}.timeslot-info{background:#f8f9fa;padding:1rem;border-radius:4px;margin-bottom:1.5rem;border-left:4px solid #007bff}.timeslot-info p{margin:.5rem 0;color:#666}.timeslot-info p:first-child{margin-top:0}.timeslot-info p:last-child{margin-bottom:0}.available-spots{color:#155724;font-weight:600}.form-help-text{display:block;margin-top:.25rem;font-size:.875rem;color:#666}.form-help-text.error-text{color:#dc3545;font-weight:500}.signup-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:600;color:#333}.form-group input{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.form-group input:disabled{background:#f5f5f5;cursor:not-allowed}.form-actions{display:flex;gap:1rem;margin-top:1rem}.cancel-button,.submit-button{flex:1;padding:.75rem 1.5rem;border:none;border-radius:4px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s}.cancel-button{background:#6c757d;color:#fff}.cancel-button:hover:not(:disabled){background:#5a6268}.submit-button{background:#007bff;color:#fff}.submit-button:hover:not(:disabled){background:#0056b3}.cancel-button:disabled,.submit-button:disabled{background:#ccc;cursor:not-allowed}.error-message{background:#f8d7da;color:#721c24;padding:1rem;border-radius:4px;margin-bottom:1rem;border:1px solid #f5c6cb}.success-message{background:#d4edda;color:#155724;padding:1rem;border-radius:4px;margin-bottom:1rem;border:1px solid #c3e6cb}.loading{text-align:center;padding:2rem;font-size:1.2rem;color:#666}.staffing-table tbody tr.booked-timeslot{background-color:#66bb6a!important}.staffing-table tbody tr.booked-timeslot:hover{background-color:#4caf50!important}.staffing-table tbody tr.booked-timeslot td{background-color:transparent}@media (max-width: 768px){.public-signup-page{padding:clamp(.35rem,2vw,1rem)}.password-form-container{margin:1.5rem auto;padding:1.25rem}.event-header h1{font-size:1.5rem}.signup-form-card{padding:1.25rem}.staffing-table{min-width:0}}@media (max-width: 480px){.public-signup-page{padding:clamp(.25rem,1.5vw,.75rem)}.password-form-container,.signup-form-card{padding:1rem}.form-actions{flex-direction:column}.cancel-button,.submit-button{width:100%}}.user-form-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;padding:1rem}.user-form-card{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 4px 6px #0003;width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.user-form-card h2{color:#333;margin-bottom:1.5rem}.user-form{display:flex;flex-direction:column}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:#333;font-weight:500}.form-group .required{color:#dc3545}.form-input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;box-sizing:border-box}.form-input:focus{outline:none;border-color:#4a7c59;box-shadow:0 0 0 2px #4a7c5933}.form-input:disabled{background-color:#f5f5f5;cursor:not-allowed}.form-help{margin-top:.25rem;font-size:.875rem;color:#666}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.checkbox-label input[type=checkbox]{width:auto;cursor:pointer}.checkbox-label span{color:#333;font-weight:400}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem}.cancel-button,.save-button{padding:.75rem 1.5rem;border:none;border-radius:4px;cursor:pointer;font-size:1rem;font-weight:500;transition:background-color .2s;height:2.5rem;line-height:1.5;box-sizing:border-box;display:inline-flex;align-items:center;justify-content:center}.cancel-button{background-color:#6c757d;color:#fff}.cancel-button:hover:not(:disabled){background-color:#5a6268}.save-button{background-color:#4a7c59;color:#fff}.save-button:hover:not(:disabled){background-color:#3d6b1f}.cancel-button:disabled,.save-button:disabled{opacity:.6;cursor:not-allowed}.users-page{max-width:1200px;margin:0 auto;padding:2rem}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.page-header h1{color:#333;font-size:2rem}.logout-button{padding:.5rem 1rem;background-color:#dc3545;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1rem;transition:background-color .2s;height:2.5rem;line-height:1.5;box-sizing:border-box;display:inline-flex;align-items:center;justify-content:center}.logout-button:hover{background-color:#c82333}.back-button{padding:.5rem 1rem;background-color:#4a7c59;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1rem;transition:background-color .2s;height:2.5rem;line-height:1.5;box-sizing:border-box;display:inline-flex;align-items:center;justify-content:center}.back-button:hover{background-color:#3d6b1f}.users-list{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #2d501626;border:1px solid #e8f5e9}.users-table{width:100%;border-collapse:collapse}.users-table thead{background-color:#f5f5f5}.users-table th{padding:1rem;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #ddd}.users-table td{padding:1rem;border-bottom:1px solid #eee;color:#666}.users-table tbody tr:hover{background-color:#f9f9f9}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.875rem;font-weight:500}.status-badge.active{background-color:#d4edda;color:#155724}.status-badge.inactive{background-color:#f8d7da;color:#721c24}.actions-cell{vertical-align:top;text-align:right}.user-actions{display:flex;gap:.25rem;flex-wrap:wrap;justify-content:flex-end;align-items:flex-start}.users-page .action-button{background:none;border:none;cursor:pointer;padding:.25rem;font-size:1rem;opacity:.6;transition:opacity .2s;display:flex;align-items:center;justify-content:center;line-height:1}.users-page .action-button:hover{opacity:1}.users-page .action-button:active{transform:scale(.95)}.create-button{padding:.75rem 1.5rem;background-color:#4a7c59;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1rem;font-weight:500;transition:background-color .2s;height:2.5rem;line-height:1.5;box-sizing:border-box;display:inline-flex;align-items:center;justify-content:center}.create-button:hover{background-color:#3d6b1f}.error-message{color:#dc3545;background-color:#f8d7da;border:1px solid #f5c6cb;padding:.75rem;border-radius:4px;margin-bottom:1rem}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#e8f5e9,#f1f8e9,#fff9e6);background-attachment:fixed;color:#2d5016}#root{min-height:100vh}.loading{display:flex;justify-content:center;align-items:center;min-height:100vh;font-size:1.2rem;color:#666}.error-message{background-color:#fee;color:#c33;padding:1rem;border-radius:4px;margin-bottom:1rem;border:1px solid #fcc}
