:root{--primary-color: #007bff;--primary-hover-color: #0056b3;--secondary-color: #6c757d;--text-color: #212529;--text-on-colored-bg: #1a1a1a;--border-color: #dee2e6;--success-color: #28a745;--error-color: #dc3545;--disabled-color: #e9ecef;--background-color: #f4f1ee;--surface-color: #ffffff;--border-radius: 8px;--box-shadow: 0 4px 6px rgba(0, 0, 0, .1);--transition-speed: .2s ease-in-out}*,*:before,*:after{box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;margin:0;background-color:var(--background-color);color:var(--text-color);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;position:relative;overflow-x:hidden}#app{padding:1rem;max-width:1300px;margin:2rem auto}.booking-tool-header{margin-bottom:2rem;background-color:#fdfdffcc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:1.5rem;display:flex;flex-direction:column;align-items:center;gap:1.5rem}.header-content{display:flex;align-items:center;justify-content:center;gap:1.5rem;flex-wrap:nowrap;width:100%}.header-logo{width:80px;height:80px;flex-shrink:0;border-radius:12px;box-shadow:var(--box-shadow)}.header-text{text-align:left}.booking-tool-header h1{font-size:2.5rem;font-weight:700;margin:0 0 .25rem}.booking-tool-header p{font-size:1.1rem;color:var(--secondary-color);max-width:600px;margin:0}.main-nav{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}.main-nav .btn{width:auto;min-width:160px}.main-container{display:grid;grid-template-columns:2fr 1fr;gap:2rem;align-items:start}.events-section{background:transparent}.events-container-box{background:var(--surface-color);border-radius:var(--border-radius);box-shadow:var(--box-shadow);padding:1.5rem}.month-navigator{display:flex;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border-color)}.month-navigator h2{margin:0;font-size:1.5rem;font-weight:600}.event-list-container{max-height:80vh;overflow-y:auto;padding-right:10px}.week-header{font-size:1.2rem;font-weight:600;color:var(--secondary-color);margin:1.5rem 0 1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-color)}.event-list{list-style:none;padding:0;margin:0}.event-item{padding:.75rem 1rem;margin-bottom:.5rem;border-radius:6px;display:flex;align-items:center;gap:1rem;color:var(--text-on-colored-bg);font-size:.95rem;border:1px solid rgba(0,0,0,.1);position:relative}.event-item.disabled{cursor:not-allowed;color:var(--secondary-color);text-decoration:line-through}.event-item.disabled:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background-color:#ffffffb3;border-radius:6px;z-index:0}.event-item>*{position:relative;z-index:1}.event-item input[type=checkbox],.form-group-checkbox input[type=checkbox]{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:18px;height:18px;border:1.5px solid #b0b0b0;border-radius:4px;cursor:pointer;position:relative;flex-shrink:0;background-color:#fff}.event-item input[type=checkbox]:checked,.form-group-checkbox input[type=checkbox]:checked{background-color:#fff;border-color:#1a1a1a}.event-item input[type=checkbox]:checked:before,.form-group-checkbox input[type=checkbox]:checked:before{content:"✔";font-size:14px;color:#000;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.event-legend{margin-bottom:1.5rem;padding:1rem;background-color:var(--disabled-color);border-radius:var(--border-radius)}.event-legend h4{margin-top:0;margin-bottom:.75rem;font-weight:600;font-size:1.1rem;color:var(--text-color)}.legend-list{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:1rem;row-gap:.5rem}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:var(--secondary-color)}.legend-color-swatch{width:16px;height:16px;border-radius:4px;flex-shrink:0;border:1px solid rgba(0,0,0,.15)}.event-category-orchid{background-color:orchid}.event-category-limegreen{background-color:#32cd32}.event-category-skyblue{background-color:#87ceeb}.event-category-peru{background-color:peru}.event-category-gold{background-color:gold}.event-category-white{background-color:#f6f6c9;border:1px solid var(--border-color)}.event-category-darkkhaki{background-color:#bdb76b}.event-category-tomato{background-color:tomato}.event-details{flex-grow:1;cursor:pointer}.event-item.disabled .event-details{cursor:not-allowed}.event-capacity{font-weight:500;text-align:right;white-space:nowrap;font-size:.9rem}.capacity-full{color:var(--error-color);font-weight:600}.booking-panel{position:sticky;top:2rem}.booking-summary,.booking-form-container,.confirmation-message{background:var(--surface-color);border-radius:var(--border-radius);box-shadow:var(--box-shadow);padding:1.5rem;margin-bottom:2rem}.booking-summary h3,.booking-form-container h3{margin-top:0;border-bottom:1px solid var(--border-color);padding-bottom:.75rem;margin-bottom:1rem}.selected-event-list{list-style:none;padding:0;margin:0 0 1.5rem;max-height:200px;overflow-y:auto}.selected-event-item{font-size:.9rem;padding:.75rem;display:flex;justify-content:space-between;align-items:center;color:var(--text-on-colored-bg);border-radius:6px;margin-bottom:.5rem;border:1px solid var(--border-color)}.selected-event-time{color:var(--secondary-color);font-size:.85rem;white-space:nowrap;margin-left:1rem}.form-group{margin-bottom:1rem}.form-group:last-child{margin-bottom:0}.form-group label{display:block;font-weight:500;margin-bottom:.5rem}.form-group input,.form-group select{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:6px;font-size:1rem;transition:border-color var(--transition-speed),box-shadow var(--transition-speed);background-color:#fff;color:#000;font-family:inherit}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #007bff40}input[type=date]::-webkit-calendar-picker-indicator,input[type=time]::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.7;filter:invert(.5);transition:opacity var(--transition-speed);margin-right:.5rem}input[type=date]::-webkit-calendar-picker-indicator:hover,input[type=time]::-webkit-calendar-picker-indicator:hover{opacity:1}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group-checkbox{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.form-group-checkbox label{margin-bottom:0;font-weight:400}.form-group-checkbox a{color:var(--primary-color);text-decoration:none}.form-group-checkbox a:hover{text-decoration:underline}.legal-notice{font-size:.9rem;font-style:italic;color:var(--secondary-color);margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.form-hint{font-size:.9rem;text-align:center;color:var(--secondary-color);margin-top:1rem;padding:.75rem;border-radius:6px;background-color:var(--disabled-color)}.btn{display:inline-block;padding:.75rem 1.5rem;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;text-align:center;transition:background-color var(--transition-speed),transform var(--transition-speed),border-color var(--transition-speed),color var(--transition-speed)}.btn:hover{transform:translateY(-2px)}.btn-primary{background-color:var(--primary-color);color:#fff;width:100%}.btn-primary:hover{background-color:var(--primary-hover-color)}.btn-secondary{background-color:var(--surface-color);border:1px solid var(--secondary-color);color:var(--secondary-color)}.btn-secondary:hover{background-color:var(--secondary-color);color:#fff}.btn-danger{background-color:var(--error-color);color:#fff}.btn-danger:hover{background-color:#c82333}.btn-success{background-color:var(--success-color);color:#fff}.btn-success:hover{background-color:#218838}.btn:disabled{background-color:var(--disabled-color);cursor:not-allowed;transform:none;color:var(--secondary-color);border-color:var(--disabled-color)}.btn-small{padding:.25rem .75rem;font-size:.8rem;font-weight:500}.error-message,.success-message{color:var(--error-color);background-color:#f8d7da;border:1px solid #f5c6cb;padding:.75rem 1.25rem;margin-top:1rem;border-radius:.25rem}.success-message{color:#155724;background-color:#d4edda;border-color:#c3e6cb}.confirmation-message{border-left:5px solid var(--success-color)}.confirmation-message h3{margin-top:0;color:var(--success-color)}.confirmation-message a{color:var(--primary-color);word-break:break-all}.empty-state{padding:2rem;text-align:center;color:var(--secondary-color);background-color:#ffffffb3;border-radius:var(--border-radius)}.empty-state-small{padding:1rem;text-align:center;font-size:.9rem;color:var(--secondary-color);background-color:var(--disabled-color);border-radius:var(--border-radius)}.loading-state{display:flex;justify-content:center;align-items:center;min-height:50vh;font-size:1.5rem}.admin-panel{background:var(--surface-color);border-radius:var(--border-radius);box-shadow:var(--box-shadow);padding:1.5rem;max-height:80vh;overflow-y:auto}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.admin-header h2{margin:0}.admin-header .btn{width:auto}.admin-header-actions{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}.admin-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.admin-tabs .btn{width:auto}.admin-event-list{list-style:none;padding:0;margin:0}.admin-event-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;margin-bottom:.5rem;border-radius:6px;color:var(--text-on-colored-bg)}.admin-event-info{display:flex;flex-direction:column;gap:.25rem}.admin-event-info span{font-size:.9rem;opacity:.9}.admin-event-actions{display:flex;gap:.5rem;flex-shrink:0}.admin-event-actions .btn{width:auto;padding:.5rem 1rem}.booking-overview-container{padding-top:1rem}.overview-event-group{margin-bottom:2rem}.overview-event-header{padding:1rem;border-radius:6px;margin:0 0 1rem;display:flex;justify-content:space-between;align-items:center;color:var(--text-on-colored-bg)}.overview-event-info{display:flex;flex-direction:column;gap:.25rem}.overview-event-title{font-size:1.2rem;font-weight:600}.overview-event-details{font-size:.9rem;opacity:.9}.overview-event-capacity{font-size:1rem;font-weight:600;text-align:right;flex-shrink:0;margin-left:1rem}.participant-list{list-style:none;padding:0;margin:0}.participant-list li{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;border-bottom:1px solid var(--border-color);flex-wrap:wrap;gap:.5rem}.participant-list li:last-child{border-bottom:none}.participant-info strong{font-weight:600}.participant-contact{display:flex;flex-direction:column;align-items:flex-end;font-size:.9rem;color:var(--secondary-color)}.no-participants-message{padding:1rem;text-align:center;color:var(--secondary-color)}.booking-lookup-form{max-width:500px;margin:2rem auto;background:var(--surface-color);padding:2rem;border-radius:var(--border-radius);box-shadow:var(--box-shadow);text-align:center}.booking-lookup-form h2{margin-top:0}.booking-lookup-form .btn{width:100%;margin-top:1rem}.forgot-booking-id-btn{background:none;border:none;color:var(--secondary-color);text-decoration:underline;cursor:pointer;font-size:.9rem;padding:0;margin-top:1.5rem;transition:color var(--transition-speed)}.forgot-booking-id-btn:hover{color:var(--primary-color)}.manage-portal,.manage-portal-success{background:var(--surface-color);padding:2rem;border-radius:var(--border-radius);box-shadow:var(--box-shadow);max-height:80vh;overflow-y:auto}.manage-portal h2,.manage-portal-success h2{margin-top:0}.manage-portal-success{text-align:center}.manage-portal-success .success-message{margin-bottom:2rem}.manage-container{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-top:2rem}.manage-section h3{border-bottom:1px solid var(--border-color);padding-bottom:.5rem;margin-top:0}.manage-event-list{list-style:none;padding:0;margin:0}.manage-event-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem;border-radius:6px;margin-bottom:.5rem;gap:1rem;color:var(--text-on-colored-bg)}.manage-event-details{display:flex;flex-direction:column;gap:.2rem}.manage-event-details small{opacity:.9;font-size:.85rem}.cancel-warning{color:var(--error-color);font-weight:700}.manage-event-item .btn{width:auto;padding:.5rem 1rem;flex-shrink:0}.manage-footer{display:flex;justify-content:space-between;align-items:center;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border-color);flex-wrap:wrap;gap:1rem}.manage-footer .btn{width:auto}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.modal-content{background:var(--surface-color);padding:2rem;border-radius:var(--border-radius);box-shadow:0 5px 15px #0000004d;width:90%;max-width:500px;z-index:1001;animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border-color);padding-bottom:1rem;margin-bottom:1rem}.modal-header h2{margin:0;font-size:1.5rem;color:var(--text-color)}.modal-header h2:has(+.modal-close-btn){color:var(--success-color)}.modal-close-btn{background:none;border:none;font-size:2rem;cursor:pointer;color:var(--secondary-color);line-height:1}.modal-body{margin-bottom:1.5rem}.modal-body p{margin:0 0 .75rem;line-height:1.6}.booking-id{background-color:var(--disabled-color);padding:.75rem;border-radius:6px;font-size:1rem;text-align:center;margin-top:1rem}.booking-id strong{font-family:monospace}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding-top:1rem;border-top:1px solid var(--border-color)}.modal-footer .btn{width:auto;min-width:120px}.csv-instructions{background-color:var(--disabled-color);padding:1rem;border-radius:6px;margin-bottom:1.5rem;font-size:.9rem}.csv-instructions ul{padding-left:20px;margin-top:.5rem;margin-bottom:1rem}.csv-instructions pre{background-color:#333;color:#f4f4f4;padding:.75rem;border-radius:4px;white-space:pre-wrap;word-break:break-all}.csv-instructions code{font-family:monospace}input[type=file]{border:1px solid var(--border-color);border-radius:6px;padding:.5rem;width:100%}.app-footer{text-align:center;padding:1rem;margin-top:2rem}.admin-login-btn{background:none;border:none;color:var(--secondary-color);text-decoration:underline;cursor:pointer;font-size:.9rem;padding:0;transition:color var(--transition-speed)}.admin-login-btn:hover{color:var(--primary-color)}.cleanup-container{display:flex;flex-direction:column;align-items:center;gap:.5rem}.cleanup-control{min-height:38px;display:flex;justify-content:center;align-items:center}.cleanup-control .btn{width:100%}.confirm-cleanup-actions{display:flex;align-items:center;gap:.75rem;font-size:.9rem}.confirm-cleanup-actions span{color:var(--secondary-color)}.cleanup-message{font-size:.85rem;padding:.5rem .75rem!important;margin:0!important;text-align:center;width:100%;max-width:250px;border-radius:6px!important}.progress-indicator{display:flex;flex-direction:column;gap:.5rem;width:100%}.progress-indicator-label{font-size:.9rem;color:var(--secondary-color);text-align:center}.progress-bar-container{width:100%;height:8px;background-color:var(--disabled-color);border-radius:4px;overflow:hidden}.progress-bar{width:100%;height:100%;background-color:var(--primary-color);border-radius:4px;animation:indeterminate-progress 1.5s infinite linear;transform-origin:0% 50%}.admin-cleanup-progress{width:180px;justify-content:center}@keyframes indeterminate-progress{0%{transform:translate(-100%) scaleX(.1)}50%{transform:translate(0) scaleX(.8)}to{transform:translate(100%) scaleX(.1)}}@media (max-width: 992px){.main-container{grid-template-columns:1fr}.booking-panel{position:static;top:auto}.event-list-container{max-height:none}.manage-container{grid-template-columns:1fr}}@media (max-width: 576px){body{font-size:14px}#app{padding:.5rem;margin:1rem auto}.header-content{justify-content:flex-start;gap:1rem}.header-logo{width:60px;height:60px}.booking-tool-header h1{font-size:1.8rem}.booking-tool-header p{font-size:.9rem}.main-nav{flex-direction:column}.main-nav .btn{width:100%}.month-navigator{padding-bottom:.5rem;flex-direction:column;gap:.5rem}.month-navigator h2{font-size:1.25rem}.event-item{font-size:.85rem;flex-direction:column;align-items:flex-start;gap:.5rem}.modal-content{padding:1.5rem}.modal-footer{flex-direction:column-reverse;gap:.75rem}.modal-footer .btn{width:100%;min-width:unset}.modal-header h2{font-size:1.25rem}.form-row{grid-template-columns:1fr;gap:0}.form-row .form-group{margin-bottom:1rem}.admin-event-item{flex-direction:column;align-items:stretch;gap:.75rem}.admin-event-actions{justify-content:flex-end}.manage-event-item{flex-direction:column;align-items:stretch}.manage-event-item .btn{margin-top:.5rem}.manage-footer{flex-direction:column-reverse}.manage-footer .btn{width:100%}.participant-list li{flex-direction:column;align-items:flex-start}.participant-contact{align-items:flex-start}}
