:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:#ffffffde;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#242424;font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;font-weight:400;line-height:1.5}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}a{color:#646cff;-webkit-text-decoration:inherit;text-decoration:inherit;font-weight:500}a:hover{color:#535bf2}body{place-items:center;min-width:320px;min-height:100vh;margin:0;display:flex}h1{font-size:3.2em;line-height:1.1}button{cursor:pointer;background-color:#1a1a1a;border:1px solid #0000;border-radius:8px;padding:.6em 1.2em;font-family:inherit;font-size:1em;font-weight:500;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}*{box-sizing:border-box;margin:0;padding:0}html,body{width:100%;height:100%;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#8fa9ba 0%,#7a93a5 100%) fixed;min-height:100vh;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;font-size:120%;line-height:1.5}#root{width:100%;min-height:100vh;margin:0;padding:0}.app{justify-content:center;align-items:flex-start;width:100%;min-height:100vh;padding:20px;display:flex}.container{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:20px;flex-direction:column;width:100%;max-width:1200px;height:95vh;max-height:95vh;margin:0;display:flex;overflow:visible;box-shadow:0 20px 40px #0000001a}.container>.header{flex-shrink:0}.container>.tab-carousel{flex-direction:column;flex:1;min-height:0;display:flex}.container>:not(:last-child){border-bottom:1px solid #0000000d}.error{color:#fff;background:linear-gradient(135deg,#ff6b6b,#feca57);border:none;border-radius:10px;margin:20px 30px;padding:20px;font-weight:500}button,input{font-family:inherit}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.2}p{margin-bottom:.5em}@media (max-width:768px){body{overflow-x:hidden}.app{align-items:stretch;padding:10px}.container{border-radius:15px;max-height:85vh}.error{margin:15px 20px;padding:15px;font-size:.9rem}}@media (max-width:480px){.app{padding:5px}.container{border-radius:10px;max-height:90vh}}.header{color:#fff;text-align:center;z-index:3;background:linear-gradient(135deg,#4a5d6d 0%,#5a7080 100%);border-radius:20px 20px 0 0;flex-shrink:0;padding:20px;position:relative;overflow:hidden}.header-logo{z-index:1;filter:brightness(0)invert();width:90%;max-width:420px;height:auto;margin-bottom:12px;position:relative}.header p{opacity:.95;z-index:1;letter-spacing:1px;margin-bottom:0;font-family:Book Antiqua,Palatino Linotype,Georgia,serif;font-size:1.68em;font-style:normal;font-weight:500;position:relative}.beta-badge{color:#fff;letter-spacing:1.5px;text-shadow:1px 1px 2px #00000080;z-index:10;background:linear-gradient(135deg,#a8b5a0 0%,#b8c5b0 100%);border:2px solid #ffffff4d;border-radius:20px;padding:6px 14px;font-size:.75em;font-weight:700;position:absolute;top:15px;box-shadow:0 2px 8px #0003}.beta-left{left:15px}.beta-right{right:15px}@media (max-width:768px){.header{padding:15px}.header-logo{max-width:330px;margin-bottom:10px}.header p{font-size:1.1em}.beta-badge{padding:5px 10px;font-size:.65em;top:10px}.beta-left{left:10px}.beta-right{right:10px}}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0009;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.modal-content{background:#fff;border-radius:16px;width:90%;max-width:500px;max-height:90vh;animation:.3s slideUp;overflow:auto;box-shadow:0 20px 60px #0000004d}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.modal-header{border-bottom:1px solid #e1e5e9;justify-content:space-between;align-items:center;padding:24px 24px 16px;display:flex}.modal-header h2{color:#333;margin:0;font-size:1.5em;font-weight:600}.modal-close{color:#999;cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;padding:0;font-size:32px;transition:all .2s;display:flex}.modal-close:hover{color:#333;background:#f5f5f5}.modal-body{padding:24px}.event-name{color:#4a5d6d;margin-bottom:12px;font-size:1.1em;font-weight:600}.modal-description{color:#666;margin-bottom:24px;line-height:1.5}.input-container{flex-direction:column;gap:8px;margin-bottom:16px;display:flex}.input-row{grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px;display:grid}.input-container label{color:#333;font-size:.95em;font-weight:600}.required{color:#ff6b6b;margin-left:2px}.input-container input{color:#fff;background-color:#000;border:2px solid #e1e5e9;border-radius:10px;padding:12px 16px;font-size:14px;transition:all .3s}.input-container input:focus{border-color:#4a5d6d;outline:none;box-shadow:0 0 20px #4a5d6d33}.input-container input::placeholder{color:#999}.error-text{color:#ff6b6b;font-size:.85em;font-weight:500}.modal-footer{justify-content:flex-end;gap:12px;padding:16px 24px 24px;display:flex}.btn-cancel,.btn-submit{cursor:pointer;border:none;border-radius:10px;padding:12px 24px;font-size:14px;font-weight:600;transition:all .3s}.btn-cancel{color:#666;background:#f5f5f5}.btn-cancel:hover{color:#333;background:#e1e5e9}.btn-submit{color:#fff;background:linear-gradient(135deg,#4a5d6d 0%,#5a7080 100%);box-shadow:0 4px 15px #4a5d6d4d}.btn-submit:hover{transform:translateY(-2px);box-shadow:0 6px 20px #5a708066}.btn-submit:active{transform:translateY(0)}@media (max-width:768px){.modal-content{width:95%;margin:20px}.modal-header h2{font-size:1.3em}.input-row{grid-template-columns:1fr}.modal-footer{flex-direction:column-reverse}.btn-cancel,.btn-submit{width:100%}}.error-modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:2000;background:#000000b3;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.error-modal-content{background:#fff;border:3px solid #ff6b6b;border-radius:16px;width:90%;max-width:500px;max-height:90vh;animation:.3s slideUp;overflow:auto;box-shadow:0 20px 60px #0000004d}.error-modal-header{color:#fff;background:linear-gradient(135deg,#ff6b6b,#ee5a6f);border-bottom:2px solid #ffe0e0;border-radius:13px 13px 0 0;justify-content:space-between;align-items:center;padding:24px 24px 16px;display:flex}.error-modal-header h2{margin:0;font-size:1.5em;font-weight:600}.error-modal-close{color:#fff;cursor:pointer;background:#fff3;border:none;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;padding:0;font-size:32px;transition:all .2s;display:flex}.error-modal-close:hover{background:#ffffff4d;transform:scale(1.1)}.error-modal-body{padding:24px}.error-modal-message{color:#333;margin-bottom:16px;font-size:1.1em;font-weight:600}.error-modal-instruction{color:#666;margin-bottom:0;font-size:1em;line-height:1.6}.error-modal-footer{justify-content:center;padding:16px 24px 24px;display:flex}.error-modal-btn-close{cursor:pointer;color:#fff;background:linear-gradient(135deg,#ff6b6b,#ee5a6f);border:none;border-radius:10px;padding:12px 32px;font-size:14px;font-weight:600;transition:all .3s;box-shadow:0 4px 15px #ff6b6b4d}.error-modal-btn-close:hover{transform:translateY(-2px);box-shadow:0 6px 20px #ff6b6b66}.error-modal-btn-close:active{transform:translateY(0)}@media (max-width:768px){.error-modal-content{width:95%;margin:20px}.error-modal-header h2{font-size:1.3em}}.event-table-container{z-index:1;background:#fff;border-radius:8px;flex-direction:column;flex:1;min-height:0;display:flex;position:relative;overflow:hidden;box-shadow:0 2px 8px #0000001a}.table-container{scroll-behavior:smooth;scrollbar-width:thin;scrollbar-color:#5a7080 #f0f0f0;-webkit-overflow-scrolling:touch;flex:1;min-height:0;overflow:auto}.table-container::-webkit-scrollbar{width:8px;height:8px}.table-container::-webkit-scrollbar-track{background:#f0f0f0;border-radius:4px}.table-container::-webkit-scrollbar-thumb{background:#5a7080;border-radius:4px}.table-container::-webkit-scrollbar-thumb:hover{background:#4a5d6d}table{border-collapse:collapse;background:#fff;width:100%}thead{color:#fff;z-index:10;background:linear-gradient(135deg,#a8b5a0 0%,#b8c5b0 100%);position:sticky;top:0}th{text-align:left;text-transform:capitalize;letter-spacing:.5px;text-shadow:1px 1px 2px #0009;padding:20px 15px;font-size:1.08em;font-weight:600}th:first-child{width:12%}th:nth-child(2){width:10%}th:nth-child(3){width:20%}th:nth-child(4){width:43%}th:nth-child(5){text-align:center;width:15%}tbody tr{border-bottom:1px solid #0000000d;transition:all .3s}tbody tr:nth-child(2n){background:#5a708008}tbody tr:hover{background:linear-gradient(135deg,#4a5d6d1a,#5a70801a);transform:scale(1.01);box-shadow:0 5px 20px #0000001a}tbody tr.example-row{opacity:.7;background:linear-gradient(135deg,#4a5d6d0d,#5a70800d)}td{vertical-align:top;padding:18px 15px}.date-cell{color:#5a7080;white-space:nowrap;font-size:1.14em;font-weight:600}.time-cell{color:#666;white-space:nowrap;font-size:1.08em}.event-title{color:#333;margin-bottom:5px;font-size:1.26em;font-weight:600}.event-description{color:#666;font-size:1.08em;line-height:1.4}.event-tags{color:#003d7a;margin-top:8px;font-size:.95em;font-weight:700}.event-tags strong{color:#003d7a}.action-cell{text-align:center}.signup-btn{cursor:pointer;color:#fff;background:linear-gradient(135deg,#4a5d6d 0%,#5a7080 100%);border:none;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;padding:0;font-size:24px;font-weight:300;line-height:1;transition:all .3s;display:inline-flex;box-shadow:0 2px 8px #4a5d6d4d}.signup-btn:hover{transform:scale(1.1)rotate(90deg);box-shadow:0 4px 12px #5a708080}.signup-btn:active{transform:scale(1.05)rotate(90deg)}.no-events{text-align:center;color:#666;padding:60px 30px;font-size:1.1em}@media (max-width:768px){.event-table-container{border-radius:6px}.table-container{overflow-x:hidden}table{table-layout:fixed;width:100%;display:table}th,td{letter-spacing:0;word-wrap:break-word;overflow-wrap:break-word;padding:10px 4px;font-size:.65em}th{white-space:nowrap;padding:12px 3px;font-size:.6em}.header-icon{display:none}th:first-child,td:first-child{width:18%}th:nth-child(2),td:nth-child(2){width:15%}th:nth-child(3),td:nth-child(3){width:22%}th:nth-child(4),td:nth-child(4){width:30%}th:nth-child(5),td:nth-child(5){width:15%}.date-cell,.time-cell{white-space:normal;font-size:.7em}.event-title{font-size:.8em;line-height:1.2}.event-description{max-height:none;font-size:.7em;line-height:1.3}.signup-btn{width:32px;height:32px;font-size:18px}.no-events{padding:40px 20px;font-size:1em}}@media (max-width:480px){th,td{padding:8px 4px;font-size:.7em}.event-title{font-size:.75em}.event-description{font-size:.65em;line-height:1.2}.date-cell,.time-cell{font-size:.65em}.signup-btn{width:28px;height:28px;font-size:16px}}.example-notice{text-align:center;color:#666;padding:20px;font-size:.9em;font-style:italic}.example-notice p{margin-bottom:10px}@media (max-width:768px){th,td{padding:12px 10px}}.qr-code-container{flex:1;justify-content:center;align-items:center;min-height:0;padding:1rem;display:flex;overflow-y:auto}.qr-code-content{text-align:center;background:#fff;border-radius:12px;width:100%;max-width:600px;padding:1.5rem;box-shadow:0 4px 6px #0000001a}.qr-code-content h2{color:#333;margin-bottom:1rem;font-size:1.75rem}.qr-code-wrapper{background:#fff;border:2px solid #e0e0e0;border-radius:8px;justify-content:center;max-width:400px;margin:1rem auto;padding:1rem;display:flex}.qr-code-url{color:#4a5d6d;word-break:break-all;margin:.75rem 0 .5rem;font-size:1.2rem;font-weight:600}.qr-code-instruction{color:#666;margin-top:.5rem;margin-bottom:0;font-size:1rem;line-height:1.6}@media (max-width:768px){.qr-code-container{padding:1rem}.qr-code-content{padding:2rem 1.5rem}.qr-code-content h2{margin-bottom:1.5rem;font-size:1.5rem}.qr-code-wrapper{margin:1.5rem auto;padding:1rem}.qr-code-url{font-size:1rem}.qr-code-instruction{font-size:.95rem}}.circular-timer{justify-content:center;align-items:center;display:inline-flex;position:relative}.circular-timer svg{transform:scaleX(-1)}.progress-circle{transition:stroke-dashoffset 50ms linear}.timer-text{color:#4a5d6d;pointer-events:none;font-size:14px;font-weight:600;position:absolute}.tab-carousel{flex-direction:column;flex:1;width:100%;min-height:0;display:flex;overflow:hidden}.tab-navigation{background:#fff;border-bottom:2px solid #e5e7eb;flex-wrap:wrap;flex-shrink:0;align-items:center;gap:.5rem;padding:1rem 1.5rem;display:flex}.tab-button{cursor:pointer;color:#6b7280;background:#fff;border:2px solid #e5e7eb;border-radius:8px;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:1.2rem;font-weight:500;transition:all .2s;display:flex}.tab-button:hover{background:#f9fafb;border-color:#a8b5a0}.tab-button.active{color:#fff;text-shadow:1px 1px 2px #0009;background:linear-gradient(135deg,#a8b5a0 0%,#b8c5b0 100%);border-color:#a8b5a0}.tab-icon{font-size:1.44rem}.tab-label{font-weight:600}.timer-container{align-items:center;gap:.5rem;margin-left:auto;padding:0 1rem;display:flex}.tab-content{flex:1;min-height:0;padding:1rem 1.5rem;position:relative;overflow:hidden auto}.tab-panel{height:100%;animation:.3s ease-in fadeIn;display:none}.tab-panel.active{flex-direction:column;display:flex}@media (max-width:768px){.tab-navigation{flex-flow:row;justify-content:center;gap:.5rem;padding:.75rem}.tab-button{white-space:nowrap;border-radius:8px;flex:1;min-width:0;max-width:48%;padding:.7rem .4rem;font-size:.75rem;overflow:hidden}.tab-icon{font-size:1rem}.tab-label{font-size:.7rem;font-weight:600}.tab-button:nth-child(3),.timer-container{display:none}}.loading{text-align:center;color:#666;z-index:1;background:#fff;flex-direction:column;align-items:center;gap:20px;padding:40px;font-size:1.1em;display:flex;position:relative}.spinner{border:4px solid #f3f3f3;border-top-color:#4facfe;border-radius:50%;width:40px;height:40px;animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}
