:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;--color-text: #213547;--color-background: #ffffff;--color-background-soft: #f9f9f9;--color-border: #dee2e6;--color-primary: #007bff;--color-primary-hover: #0056b3;--color-secondary-text: #6c757d;--color-card-bg: #ffffff;--color-card-shadow: rgba(0, 0, 0, .1);--color-input-bg: #ffffff;--color-input-border: #ccc;--color-error-text: #dc3545;--color-error-bg: #f8d7da;--color-cover-button: #dc3545;--color-cover-button-hover: #c82333;--color-cover-button-text: #fff;color-scheme:light dark;color:var(--color-text);background-color:var(--color-background);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:var(--color-primary);text-decoration:inherit}a:hover{color:var(--color-primary-hover)}body{margin:0;min-width:320px;min-height:100vh;color-scheme:dark}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:var(--color-background-soft);cursor:pointer;transition:border-color .25s}button:hover{border-color:var(--color-primary)}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}.confirmation-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:1050}.confirmation-modal-content{background-color:#fff;padding:24px 32px;border-radius:12px;box-shadow:0 5px 15px #0003;max-width:400px;width:90%;text-align:center}.confirmation-modal-content h2{margin-top:0;margin-bottom:16px;font-size:1.25rem;color:#333}.confirmation-modal-content p{margin-bottom:24px;color:#555;font-size:1rem;line-height:1.5}.confirmation-modal-actions{display:flex;justify-content:center;gap:16px}.modal-button{padding:10px 20px;border:none;border-radius:8px;font-size:1rem;cursor:pointer;transition:background-color .2s,box-shadow .2s}.cancel-button{background-color:#eee;color:#333}.cancel-button:hover{background-color:#ddd}.confirm-button{background-color:#f44336;color:#fff}.confirm-button:hover{background-color:#d32f2f;box-shadow:0 2px 4px #0003}.event-card{border:1px solid var(--color-border);border-radius:8px;overflow:hidden;background-color:var(--color-card-bg);box-shadow:0 2px 4px var(--color-card-shadow);transition:transform .2s ease-in-out,box-shadow .2s ease-in-out;display:flex;flex-direction:column}.event-card:hover{transform:translateY(-3px);box-shadow:0 4px 8px var(--color-card-shadow)}.card-link{text-decoration:none;color:var(--color-text);display:flex;flex-direction:column;height:100%}.event-image{width:100%;height:150px;object-fit:cover;display:block}.event-info{padding:1rem;flex-grow:1;display:flex;flex-direction:column;justify-content:space-between}.event-info h3{margin-top:0;margin-bottom:.5rem;font-size:1.1rem}.event-info p{margin-bottom:.5rem;font-size:.9rem;color:var(--color-secondary-text)}.button-group{display:flex;justify-content:space-between;align-items:center;margin-top:auto;gap:8px}.edit-link{font-size:.8rem;color:var(--color-primary);text-decoration:none;padding:6px 12px;border:1px solid var(--color-primary);border-radius:20px;transition:background-color .2s ease,color .2s ease;background:transparent;cursor:pointer}.edit-link:hover{background-color:var(--color-primary);color:var(--color-background)}.payment-link{font-size:.8rem;text-decoration:none;padding:6px 12px;border-radius:20px;transition:background-color .2s ease,color .2s ease;background-color:#4caf50;color:#fff;border:none;cursor:pointer;display:flex;align-items:center;gap:4px}.payment-link:hover{background-color:#45a049}.home-page{padding:1rem}.home-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:.5rem;border-bottom:1px solid var(--color-border)}.home-header h2{margin:0}.create-event-button{background-color:var(--color-primary);color:var(--color-background);padding:.5rem 1rem;border-radius:20px;text-decoration:none;font-weight:500;transition:background-color .2s ease}.create-event-button:hover{background-color:var(--color-primary-hover)}.home-page>p{text-align:center;color:var(--color-secondary-text);margin-top:2rem}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0009;display:flex;justify-content:center;align-items:center;z-index:1000}.modal{background:#fff;padding:20px;border-radius:5px;width:80%;max-width:600px;position:relative}.modal-header{display:flex;justify-content:flex-end;margin-bottom:10px}.modal-close{background:none;border:none;font-size:24px;cursor:pointer}.backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0006;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;justify-content:center;align-items:center;z-index:1000}.event-form{width:100%;max-width:570px;min-width:320px;margin:12px;background-color:var(--color-card-bg);border-radius:16px;border:1px solid var(--color-border);max-height:calc(100vh - 24px);box-shadow:0 1px 3px #0003;display:flex;flex-direction:column}.header{display:flex;justify-content:space-between;align-items:flex-start;padding:20px 20px 12px}.header h2{font-size:22px;font-weight:400;margin:0 0 4px;color:var(--color-text)}.header p{color:var(--color-secondary-text);font-size:14px;margin:0}.close-btn{background:none;border:none;font-size:24px;color:var(--color-secondary-text);padding:8px;cursor:pointer;border-radius:50%;margin:-4px}.close-btn:hover{background-color:#0000000d}.event-form-content{padding:0 20px}.image-upload{position:relative;width:100%;height:160px;background-color:var(--color-alternate);border-radius:16px;margin:8px 0;overflow:hidden;min-height:160px;max-height:160px;cursor:pointer}.upload-placeholder{height:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;color:var(--color-secondary-text)}.upload-icon{font-size:36px;margin-bottom:4px}.upload-placeholder h3{font-size:16px;margin:0 0 2px}.upload-placeholder p{font-size:12px;margin:0}.cover-preview{width:100%;height:100%;padding:0}.upload-loading{position:absolute;top:0;left:0;width:100%;height:100%;background-color:#00000080;border-radius:16px;display:flex;flex-direction:column;justify-content:center;align-items:center;color:#fff}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.upload-loading .upload-icon{animation:spin 1s linear infinite}.upload-loading p{margin:8px 0 0;font-size:14px;color:#fff}.upload-error{position:absolute;bottom:0;left:0;right:0;padding:12px;background-color:#f44336e6;color:#fff;font-size:14px;text-align:center;border-bottom-left-radius:16px;border-bottom-right-radius:16px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.upload-error:before{content:"⚠️";margin-right:8px}.cover-preview img{width:100%;height:100%;object-fit:cover;border-radius:16px}.event-form-content{flex:1;overflow-y:auto;padding:0 20px}.form-group{margin-bottom:16px}.form-group .MuiFormControl-root{width:100%}.form-group .MuiInputBase-root{border-radius:12px;background-color:var(--color-background)}.form-group .MuiInputBase-input{padding:16px;font-size:16px;height:20px;color:var(--color-text)}.form-group .MuiInputLabel-root{color:var(--color-secondary-text);font-size:14px;transform:translate(16px,16px) scale(1)}.form-group .MuiInputLabel-root.Mui-focused,.form-group .MuiInputLabel-root.MuiInputLabel-shrink{transform:translate(14px,-8px) scale(.75);color:var(--color-primary)}.form-group .MuiOutlinedInput-notchedOutline{border-color:var(--color-secondary);border-width:1px;border-radius:12px}.form-group .MuiOutlinedInput-root.Mui-focused .MuiOutlinedInput-notchedOutline{border-color:var(--color-primary)}.form-actions{padding:12px 20px;border-top:1px solid var(--color-border);display:flex;justify-content:space-between;background-color:var(--color-card-bg);margin-top:auto}.form-actions .delete-button{background-color:transparent;color:var(--color-error, #f44336);border:1px solid currentColor}.form-actions .delete-button:hover:not(:disabled){background-color:#f443361a}.form-actions .action-buttons{display:flex;gap:8px}.form-actions button{padding:12px 24px;background-color:var(--color-primary);color:#fff;border:none;min-width:120px;border-radius:30px;font-size:14px;font-weight:500;cursor:pointer}.form-actions button:disabled{opacity:.6;cursor:not-allowed}hr{border:none;height:1px;background-color:var(--color-border);margin:12px 0}.error-message{color:var(--color-error);background-color:var(--color-error-bg);padding:8px 12px;border-radius:8px;margin:0 20px 12px;text-align:center;font-size:14px}@media (max-width: 700px){.event-form{margin:0;height:100vh;border-radius:0}}.delete-confirmation{padding:24px;min-width:320px;max-width:400px}.delete-confirmation h2{margin:0 0 16px;font-size:20px;color:var(--color-error, #f44336)}.delete-confirmation p{margin:0 0 24px;font-size:16px;color:var(--color-text);line-height:1.5}.modal-actions{display:flex;justify-content:flex-end;gap:12px}.modal-actions button{padding:10px 20px;border-radius:20px;font-size:14px;cursor:pointer;border:1px solid var(--color-border);background:transparent;color:var(--color-text)}.modal-actions button.delete-button{background-color:var(--color-error, #f44336);color:#fff;border:none}.modal-actions button.delete-button:hover:not(:disabled){background-color:#d32f2f}.modal-actions button:hover:not(:disabled){background-color:#0000000d}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000bf;display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px}.modal-content{background-color:#fff;padding:0;border-radius:12px;width:100%;max-width:600px;box-shadow:0 4px 20px #0003;animation:modalFadeIn .3s ease-out}@keyframes modalFadeIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #eee;background-color:#f8f9fa;border-radius:12px 12px 0 0}.modal-header h2{margin:0;font-size:1.5rem;color:#32325d;font-weight:600}.close-button{background:none;border:none;font-size:24px;color:#666;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s}.close-button:hover{background-color:#eee}.payment-form{padding:24px}.payment-details{margin-bottom:24px}.amount-display{text-align:center;margin-bottom:24px;padding:20px;background-color:#f8f9fa;border-radius:8px}.amount-display h3{margin:0 0 8px;color:#6b7c93;font-size:1rem}.amount-display .amount{font-size:2.5rem;font-weight:600;color:#32325d}.payment-section{margin-bottom:24px}.payment-section h3{margin:0 0 12px;color:#32325d;font-size:1rem}.card-element-container{padding:16px;border:1px solid #e6e6e6;border-radius:8px;background:#fff;box-shadow:0 1px 3px #32325d26,0 1px #00000005;transition:box-shadow .2s}.card-element-container:focus-within{box-shadow:0 1px 3px #32325d33,0 1px #0000000d;border-color:#80bdff}.payment-info{margin-top:24px;padding:16px;background-color:#f8f9fa;border-radius:8px}.info-item{display:flex;align-items:center;gap:12px;margin-bottom:8px}.info-item:last-child{margin-bottom:0}.info-item span{font-size:1.2rem}.info-item p{margin:0;color:#6b7c93;font-size:.9rem}.error-message{margin-top:16px;padding:12px;background-color:#fff5f5;border:1px solid #feb2b2;border-radius:8px;color:#c53030;display:flex;align-items:center;gap:8px;font-size:.9rem}.button-container{display:flex;justify-content:flex-end;gap:12px;margin-top:24px;padding-top:24px;border-top:1px solid #eee}.cancel-button{padding:12px 24px;border:1px solid #e6e6e6;background:#fff;border-radius:6px;color:#6b7c93;font-size:1rem;cursor:pointer;transition:background-color .2s}.cancel-button:hover{background-color:#f8f9fa}.pay-button{padding:12px 32px;background:#5469d4;color:#fff;border:none;border-radius:6px;font-size:1rem;cursor:pointer;transition:background-color .2s;min-width:150px}.pay-button:hover:not(:disabled){background:#4a5bc8}.pay-button:disabled{background:#a5afd7;cursor:not-allowed}.processing{display:flex;align-items:center;gap:8px}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin 1s linear infinite}.profile-container{min-height:100vh;background-color:#f8f9fa;padding-bottom:2rem}.profile-content{max-width:800px;margin:0 auto;padding:1.5rem 1rem}.profile-photo-container{text-align:center;margin-top:1rem}.profile-photo{width:150px;height:150px;border-radius:50%;border:4px solid white;box-shadow:0 2px 4px #0000001a;background-color:#fff;object-fit:cover}.profile-name{text-align:center;margin:1rem 0 .5rem;font-size:1.8rem;color:#333}.profile-card{background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000001a;padding:1.5rem;margin-bottom:1.5rem}.card-title{margin-top:0;margin-bottom:1.5rem;font-size:1.2rem;color:#333;border-bottom:2px solid #f0f0f0;padding-bottom:.5rem}.profile-info-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding:.5rem 0}.info-label{font-weight:500;color:#666}.info-value{color:#333}.membership-active{color:#4caf50;font-weight:500}.activate-membership-button{background-color:#4caf50;color:#fff;border:none;padding:8px 16px;border-radius:20px;font-size:.9rem;cursor:pointer;transition:background-color .2s ease}.activate-membership-button:hover{background-color:#45a049}.stats-container{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;text-align:center}.stat-item{background:#f8f9fa;padding:1rem;border-radius:8px}.stat-value{font-size:1.8rem;font-weight:700;color:#4a90e2;margin-bottom:.5rem}.stat-label{color:#666;font-size:.9rem}.logout-button{width:100%;padding:1rem;background-color:#f8f9fa;border:1px solid #ddd;border-radius:8px;color:#dc3545;font-size:1rem;cursor:pointer;transition:background-color .2s ease;margin-top:1rem}.logout-button:hover{background-color:#f2f2f2}.form-group{display:flex;flex-direction:column;gap:.5rem;width:100%;max-width:300px;margin-bottom:1rem}.form-label{font-weight:500;color:#333;font-size:.95rem}.edit-button{background-color:#4a90e2;color:#fff;border:none;padding:8px 16px;border-radius:20px;font-size:.9rem;cursor:pointer;transition:background-color .2s ease;margin-top:1rem}.edit-button:hover{background-color:#357abd}.edit-form{display:flex;flex-direction:column;align-items:center;gap:1rem;margin-top:1rem}.edit-input{width:100%;max-width:300px;padding:8px 12px;border:1px solid #ddd;border-radius:6px;font-size:1rem}.edit-input:focus{outline:none;border-color:#4a90e2;box-shadow:0 0 0 2px #4a90e233}.edit-buttons{display:flex;gap:1rem;margin-top:1rem}.save-button,.cancel-button{padding:8px 16px;border-radius:20px;font-size:.9rem;cursor:pointer;transition:background-color .2s ease}.save-button{background-color:#4caf50;color:#fff;border:none}.save-button:hover{background-color:#45a049}.cancel-button{background-color:#f8f9fa;color:#666;border:1px solid #ddd}.cancel-button:hover{background-color:#f2f2f2}.photo-upload{position:absolute;bottom:-10px;left:50%;transform:translate(-50%)}.upload-label{background-color:#4a90e2;color:#fff;padding:6px 12px;border-radius:15px;font-size:.8rem;cursor:pointer;transition:background-color .2s ease}.upload-label:hover{background-color:#357abd}.profile-photo-container{position:relative}@media (max-width: 600px){.profile-content{padding:1rem}.profile-photo{width:120px;height:120px}.stats-container{grid-template-columns:1fr;gap:.5rem}.stat-item{padding:.8rem}.stat-value{font-size:1.5rem}}.login-container{min-height:100vh;width:100%;background:#000;position:relative;display:flex;flex-direction:column;align-items:center}.login-background{flex:1;width:100%;background-image:url(/assets/images/image.jpg);background-size:cover;background-position:center;position:relative;display:flex;justify-content:center}.login-gradient{position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(180deg,#0000,#000);display:flex;align-items:flex-end;justify-content:center;padding:48px 24px 24px}.welcome-text{color:#fff;font-family:Outfit,sans-serif;font-size:45px;text-align:center;text-shadow:2px 2px 2px rgba(0,0,0,.7);animation:fadeIn .6s ease-in-out;margin:0;padding:0}.login-form-container{background:#fff;border-radius:32px 32px 0 0;padding:24px 32px;margin-bottom:0;box-shadow:0 -4px 10px #0000004d;width:100%;max-width:400px}.login-form-title{color:#15161e;font-family:Outfit,sans-serif;font-size:24px;font-weight:600;text-align:center;margin:0 0 24px}.input-group{margin-bottom:16px}.input-group label{display:block;color:#15161e;font-family:Plus Jakarta Sans,sans-serif;font-size:14px;margin-bottom:6px;font-weight:400}.password-input-container{position:relative;display:flex;align-items:center}.input-group input{width:100%;padding:12px;border:1px solid #E0E0E0;border-radius:8px;font-family:Plus Jakarta Sans,sans-serif;font-size:16px;font-weight:500;color:#15161e;background:#fff;transition:border-color .2s ease}.input-group input::placeholder{color:#606a85;opacity:.7}.input-group input:focus{outline:none;border-color:#4b986c}.password-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;padding:0;cursor:pointer;color:#606a85;display:flex;align-items:center;justify-content:center;transition:color .2s ease}.password-toggle:focus{outline:none}.password-toggle:hover{color:#4b986c}.password-toggle i{font-size:18px}.forgot-password{text-align:right;margin:12px 0 20px}.forgot-password a{color:#4b986c;font-family:Plus Jakarta Sans,sans-serif;font-size:14px;font-weight:600;text-decoration:none;transition:opacity .2s ease}.forgot-password a:hover{opacity:.8}.login-button{width:100%;height:56px;background:#15161e;color:#fff;border:none;border-radius:28px;font-family:Outfit,sans-serif;font-size:22px;font-weight:600;cursor:pointer;margin-bottom:24px;transition:transform .2s ease,background-color .2s ease}.login-button:hover{transform:translateY(-1px);background:#2d2f3a}.login-button:active{transform:translateY(0)}.login-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.divider{display:flex;align-items:center;margin:24px 0;gap:8px}.divider-line{flex:1;height:1px;background:#e5e7eb}.divider-text{color:#606a85;font-family:Plus Jakarta Sans,sans-serif;font-size:14px;white-space:nowrap;font-weight:400}.signup-button{width:100%;height:56px;background:#606a85;color:#fff;border:none;border-radius:28px;font-family:Outfit,sans-serif;font-size:22px;font-weight:600;cursor:pointer;transition:transform .2s ease,background-color .2s ease}.signup-button:hover{transform:translateY(-1px);background:#4a5568}.signup-button:active{transform:translateY(0)}.error-message{color:#dc2626;font-family:Plus Jakarta Sans,sans-serif;font-size:14px;text-align:center;margin-bottom:16px;padding:8px;background:#fee2e2;border-radius:8px;animation:fadeIn .3s ease-in-out}.eula-dialog{padding:0;border:none;border-radius:16px;box-shadow:0 4px 20px #0003;max-width:90%;width:500px}.eula-dialog::backdrop{background-color:#00000080}.eula-content{padding:24px}.eula-content h2{color:#15161e;font-family:Outfit,sans-serif;font-size:20px;font-weight:600;text-align:center;margin:0 0 16px}.eula-text{max-height:60vh;overflow-y:auto;padding:16px;background:#f9fafb;border-radius:8px;margin-bottom:24px}.eula-text p{color:#4b5563;font-family:Plus Jakarta Sans,sans-serif;font-size:14px;line-height:1.5;margin-bottom:12px}.eula-text a{color:#4b986c;text-decoration:none;font-weight:600}.eula-buttons{display:flex;justify-content:flex-end;gap:12px}.eula-buttons button{padding:8px 16px;border-radius:20px;font-family:Plus Jakarta Sans,sans-serif;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.decline-button{background:transparent;border:1px solid #e5e7eb;color:#606a85}.decline-button:hover{background:#f3f4f6}.accept-button{background:#15161e;border:none;color:#fff}.accept-button:hover{background:#2d2f3a}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (max-width: 640px){.welcome-text{font-size:36px}.login-form-container{padding:20px 24px;margin:0 16px}.login-button,.signup-button{height:48px;font-size:18px}.eula-dialog{width:95%;margin:16px}.eula-content{padding:16px}.eula-text{padding:12px;max-height:50vh}}.page-actions{display:flex;justify-content:flex-end;gap:12px;margin-bottom:16px;padding:0 16px;max-width:1400px;margin-left:auto;margin-right:auto;width:100%;box-sizing:border-box}.page-upload-button{background-color:var(--color-primary);color:var(--color-background);padding:.5rem 1rem;border-radius:20px;text-decoration:none;font-weight:500;transition:background-color .2s ease;border:none;cursor:pointer}.page-upload-button:hover{background-color:var(--color-primary-hover)}.download-button{background-color:var(--color-success, #28a745);color:#fff;padding:.5rem 1rem;border-radius:20px;text-decoration:none;font-weight:500;transition:background-color .2s ease;border:none;cursor:pointer;display:flex;align-items:center;gap:8px}.download-button:hover{background-color:var(--color-success-hover, #218838)}.download-button:disabled{background-color:#ccc;cursor:not-allowed}.photo-grid{display:grid;gap:16px;max-width:1400px;margin:0 auto;width:100%;box-sizing:border-box}@media (min-width: 1200px){.photo-grid{grid-template-columns:repeat(6,1fr);gap:16px}}@media (min-width: 900px) and (max-width: 1199px){.photo-grid{grid-template-columns:repeat(5,1fr);gap:16px}}@media (min-width: 600px) and (max-width: 899px){.photo-grid{grid-template-columns:repeat(4,1fr);gap:14px}}@media (min-width: 400px) and (max-width: 599px){.photo-grid{grid-template-columns:repeat(3,1fr);gap:12px}}@media (max-width: 399px){.photo-grid{grid-template-columns:repeat(2,1fr);gap:10px}}.photo-item{position:relative;aspect-ratio:1;border-radius:8px;overflow:hidden;background-color:#f5f5f5;box-shadow:0 2px 4px #0000001a;transition:transform .2s ease-in-out;cursor:pointer}.photo-item:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.photo-item img{width:100%;height:100%;object-fit:cover;transition:transform .3s}.photo-item:hover img{transform:scale(1.05)}.photo-selection{position:absolute;top:8px;left:8px;z-index:2;opacity:0;transition:opacity .3s}.photo-item:hover .photo-selection,.photo-selection.selected{opacity:1}.photo-selection input[type=checkbox]{width:20px;height:20px;margin:0;cursor:pointer}.photo-selection.selected input[type=checkbox]{accent-color:var(--color-primary)}.photo-actions{position:absolute;top:8px;right:8px;display:flex;gap:8px;opacity:0;transition:opacity .3s;z-index:2}.photo-item:hover .photo-actions{opacity:1}.action-button{background-color:#0009;color:#fff;border:none;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color .3s}.action-button:hover{background-color:#000c}.loading-spinner{display:flex;justify-content:center;align-items:center;min-height:200px}.error-message{color:#f44336;text-align:center;padding:16px;background-color:#ffebee;border-radius:8px;margin:16px auto;max-width:1400px}.empty-state{text-align:center;padding:48px 16px;color:#666;background-color:#fff;border-radius:12px;box-shadow:0 2px 4px #0000000d;margin:24px auto;max-width:600px}.upload-overlay{position:fixed;bottom:24px;right:24px;background-color:#fff;padding:16px;border-radius:8px;box-shadow:0 4px 6px #0000001a;z-index:1000}.upload-progress{width:100%;height:4px;background-color:#e0e0e0;border-radius:2px;overflow:hidden;margin-top:8px}.progress-bar{height:100%;background-color:#2196f3;transition:width .3s}@media (max-width: 768px){.page-actions{padding:0 8px;margin-bottom:12px}.photo-actions,.photo-selection{opacity:1}}.image-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000d9;display:flex;justify-content:center;align-items:center;z-index:1000;cursor:pointer}.image-modal-content{position:relative;max-width:90vw;max-height:90vh;cursor:default;background-color:#fff;padding:8px;border-radius:16px;box-shadow:0 8px 16px #0000004d}.image-modal-content img{max-width:100%;max-height:90vh;object-fit:contain;border-radius:12px;display:block}.image-modal-close{position:absolute;top:-40px;right:-40px;background:none;border:none;color:#fff;font-size:32px;cursor:pointer;padding:8px;line-height:1;opacity:.8;transition:opacity .2s}.image-modal-close:hover{opacity:1}@media (max-width: 768px){.image-modal-close{top:-40px;right:0}.image-modal-content{padding:4px;border-radius:12px}.image-modal-content img{border-radius:8px}}.global-upload-indicator{position:fixed;bottom:0;left:0;width:100%;background-color:#f8f9fae6;border-top:1px solid #dee2e6;padding:8px 16px;box-sizing:border-box;display:flex;align-items:center;gap:16px;font-size:.9rem;color:#333;z-index:1000;box-shadow:0 -2px 5px #0000000d;transition:background-color .3s ease}.progress-bar-container{width:20px;height:20px;display:flex;align-items:center;justify-content:center}.progress-bar.indeterminate{border:3px solid rgba(0,123,255,.2);border-top-color:#007bff;border-radius:50%;width:20px;height:20px;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.status-message{flex-grow:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.global-upload-indicator.indicator-success{background-color:#28a745e6;color:#fff}.global-upload-indicator.indicator-error{background-color:#dc3545e6;color:#fff}.layout-container{display:flex;flex-direction:column;min-height:100vh;background-color:#f8f9fa}.main-header{display:flex;justify-content:space-between;align-items:center;padding:12px 24px;background-color:#000;color:#fff;width:100%;box-sizing:border-box;position:sticky;top:0;z-index:1000}.header-title-link{text-decoration:none;color:#fff;display:flex;align-items:center}.header-title-content{display:flex;align-items:center}.header-title-link h1{margin:0;font-size:1.5rem;font-weight:600}.header-icon{height:24px;width:auto;margin-right:8px;vertical-align:middle}.header-actions{display:flex;align-items:center;gap:16px;position:relative}.menu-button{background:none;border:none;color:#fff;font-size:1.8rem;cursor:pointer;padding:0 8px}.dropdown-menu{position:absolute;top:calc(100% + 5px);right:0;background-color:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;padding:8px 0;z-index:1100;min-width:150px;border:1px solid #eee}.dropdown-item{display:block;padding:10px 16px;color:#333;text-decoration:none;font-size:1rem;white-space:nowrap;border:none;width:100%;text-align:left;background:none;cursor:pointer}.dropdown-item:hover{background-color:#f5f5f5}.dropdown-item.delete-account-item{color:#dc3545}.dropdown-item.delete-account-item:hover{color:#fff;background-color:#dc3545}.dropdown-item.logout-button{background-color:#dc3545;color:#fff}.dropdown-item.logout-button:hover{background-color:#c82333}.main-content{flex-grow:1;padding:24px;max-width:1400px;width:100%;margin:0 auto;box-sizing:border-box}.main-footer{height:40px;background-color:#000;width:100%}@media (max-width: 768px){.main-header{padding:12px 16px}.header-title-link h1{font-size:1.2rem}.menu-button{font-size:1.5rem}.main-content{padding:16px}.main-footer{height:30px}.header-icon{height:20px}}#root{max-width:none;margin:0;padding:0;text-align:left}.app-container{display:flex;flex-direction:column;min-height:100vh}.content{flex-grow:1;padding:1rem;padding-bottom:70px;max-width:1200px;margin:0 auto}@keyframes logo-spin{}.home-page .event-grid{display:grid;gap:1.5rem}@media (min-width: 1200px){.home-page .event-grid{grid-template-columns:repeat(4,1fr)}}@media (min-width: 900px) and (max-width: 1199px){.home-page .event-grid{grid-template-columns:repeat(3,1fr)}}@media (min-width: 600px) and (max-width: 899px){.home-page .event-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 599px){.home-page .event-grid{grid-template-columns:1fr;gap:1rem}}
