:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}*{margin:0;padding:0;box-sizing:border-box}:root{--mackenzie-red: #E1001E;--old-paper: #f5f0e1;--old-paper-dark: #e8e0c9}body{font-family:Courier New,Courier,monospace;font-weight:700;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--old-paper);min-height:100vh;color:#333;background-image:url("data:image/svg+xml,%3Csvg width='100' height='100' viewBox='0 0 100 100' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100' height='100' filter='url(%23noise)' opacity='0.03'/%3E%3C/svg%3E")}.app{min-height:100vh;display:flex;flex-direction:column}.header{position:relative;padding:max(44px,calc(1rem + env(safe-area-inset-top,0px))) 1rem 1rem 1rem;background:var(--mackenzie-red);border-bottom:4px solid #b30018}.header-centered{text-align:center;padding:max(44px,calc(1.5rem + env(safe-area-inset-top,0px))) 1rem 1.5rem 1rem}.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;max-width:900px;margin:0 auto}.header-brand{display:flex;align-items:center;gap:1rem;text-align:left;min-width:0}.header-brand .logo-placeholder{width:56px;height:56px;margin:0;flex-shrink:0}.header-brand h1{font-size:1.2rem;margin-bottom:0}.header-brand h2{font-size:.9rem;margin-bottom:0}.header-brand .subtitle{font-size:.7rem;font-weight:700}.header h1{font-size:1.6rem;color:#fff;margin-bottom:.2rem;text-transform:uppercase;letter-spacing:2px}.header h2{font-size:1.2rem;color:#fffffff2;margin-bottom:.2rem}.subtitle{font-size:.9rem;color:var(--old-paper-dark);font-style:italic;font-weight:700}.bold{font-weight:700}.header-nav-desktop{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.nav-btn{padding:.5rem .9rem;background:#fff3;color:#fff;border:2px solid rgba(255,255,255,.4);font-family:Courier New,Courier,monospace;font-size:.8rem;cursor:pointer;transition:all .2s;white-space:nowrap;font-weight:700}.nav-btn:hover{background:#ffffff59;border-color:#ffffffb3}.logo-placeholder{width:90px;height:90px;margin:0 auto .75rem;background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;border:3px solid #fff;box-shadow:0 2px 10px #0003;overflow:hidden}.logo-placeholder img{width:100%;height:100%;object-fit:contain;padding:8px}.main{flex:1;padding:1.5rem;max-width:600px;margin:0 auto;width:100%}.main-gallery{max-width:900px}.photos-container{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:2rem}.photo-box{text-align:center}.photo-box h2{font-size:.8rem;margin-bottom:.4rem;color:var(--mackenzie-red);text-transform:uppercase;letter-spacing:1px;font-weight:700;border-bottom:2px solid var(--mackenzie-red);display:inline-block;padding-bottom:2px}.photo-upload{display:block;cursor:pointer;overflow:hidden;aspect-ratio:3/4;background:#fff;border:3px solid var(--mackenzie-red);transition:all .3s ease}.photo-upload:hover{transform:scale(1.02);box-shadow:0 4px 15px #e1001e4d}.photo-upload input{display:none}.photo-upload img{width:100%;height:100%;object-fit:cover}.upload-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1rem;background:var(--old-paper)}.upload-placeholder span{font-size:.75rem;color:#666}.upload-placeholder .icon{font-size:2rem;margin-bottom:.5rem}.form-container{background:#fff;padding:1.5rem;margin-bottom:2rem;border:3px solid var(--mackenzie-red)}.form-group{margin-bottom:1rem}.form-group:last-child{margin-bottom:0}.form-group label{display:block;margin-bottom:.4rem;font-size:.8rem;color:var(--mackenzie-red);text-transform:uppercase;letter-spacing:1px;font-weight:700}.form-group input[type=text],.form-group input[type=tel],.form-group input[type=password]{width:100%;padding:.75rem;border:2px solid var(--mackenzie-red);background:var(--old-paper);color:#333;font-size:1rem;font-family:Courier New,Courier,monospace;transition:all .3s ease}.form-group input::placeholder{color:#999}.form-group input:focus{outline:none;border-color:#b30018;box-shadow:0 0 10px #e1001e33}.form-hint{display:block;margin-top:.25rem;font-size:.7rem;color:#666}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group textarea{width:100%;padding:.75rem;border:2px solid var(--mackenzie-red);background:var(--old-paper);color:#333;font-size:.9rem;font-family:Courier New,Courier,monospace;transition:all .3s ease;resize:vertical;min-height:70px}.form-group textarea::placeholder{color:#999}.form-group textarea:focus{outline:none;border-color:#b30018;box-shadow:0 0 10px #e1001e33}.checkbox-group{margin-top:1.25rem}.checkbox-label{display:flex!important;flex-direction:row!important;align-items:center;gap:.6rem;cursor:pointer;text-transform:none!important;font-size:.85rem!important;color:#333!important}.checkbox-label input[type=checkbox]{width:20px!important;height:20px;accent-color:var(--mackenzie-red);cursor:pointer}.preview{background:#fff;border:3px solid var(--mackenzie-red);padding:1.5rem;margin-bottom:2rem}.preview h3{text-align:center;margin-bottom:1rem;color:var(--mackenzie-red);text-transform:uppercase;letter-spacing:2px;font-size:.8rem}.preview-content{display:flex;gap:1rem;align-items:center}.preview-photos{display:flex;gap:.5rem;flex:1}.preview-photo{flex:1;aspect-ratio:1;overflow:hidden;background:var(--old-paper);border:2px solid var(--mackenzie-red)}.preview-photo img{width:100%;height:100%;object-fit:cover}.preview-photo .placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#999}.preview-info{flex:1}.preview-info h4{font-size:.95rem;margin-bottom:.4rem;color:#333}.preview-info p{font-size:.8rem;color:#666;margin-bottom:.2rem}.event-banner{margin-bottom:2rem;border:3px solid var(--mackenzie-red);overflow:hidden;background:#fff}.event-banner img{width:100%;height:auto;display:block}.footer{text-align:center;padding:1.5rem;background:var(--old-paper-dark);border-top:3px solid var(--mackenzie-red);font-weight:700}.footer p{font-size:.75rem;color:#666}.footer-link{color:var(--mackenzie-red);font-weight:700;text-decoration:none}.footer-link:hover{text-decoration:underline}.login-container{max-width:400px;margin:2rem auto;padding:2rem;background:#fff;border:3px solid var(--mackenzie-red)}.login-container h2{text-align:center;color:var(--mackenzie-red);margin-bottom:1.5rem;font-size:1.2rem;text-transform:uppercase;letter-spacing:1px}.login-container p{text-align:center;font-size:.85rem;color:#666;margin-bottom:1rem}.login-btn{width:100%;padding:1rem;background:var(--mackenzie-red);color:#fff;border:none;font-family:Courier New,Courier,monospace;font-size:1rem;font-weight:700;text-transform:uppercase;cursor:pointer;margin-top:1rem}.login-btn:hover{background:#b30018}.login-btn:disabled{opacity:.6;cursor:not-allowed}.form-link{text-align:center;margin-top:1rem}.form-link button{background:none;border:none;color:var(--mackenzie-red);font-family:Courier New,Courier,monospace;font-size:.85rem;cursor:pointer;text-decoration:underline}.form-link button:hover{color:#b30018}.error-msg{color:var(--mackenzie-red);font-size:.8rem;margin-top:.5rem;text-align:center}.auth-tabs{display:flex;margin-bottom:1.5rem;border-bottom:2px solid var(--mackenzie-red)}.auth-tabs button{flex:1;padding:.75rem;background:transparent;border:none;border-bottom:3px solid transparent;color:#666;font-family:Courier New,Courier,monospace;font-size:.9rem;cursor:pointer}.auth-tabs button:hover{color:var(--mackenzie-red)}.auth-tabs button.active{color:var(--mackenzie-red);border-bottom-color:var(--mackenzie-red);font-weight:700}.compressing-notice{background:#fff3cd;border:2px solid #ffc107;padding:1rem;margin-bottom:1rem;text-align:center;color:#856404;font-size:.9rem}.splash{display:flex;align-items:center;justify-content:center;background:var(--mackenzie-red);color:#fff;text-align:center}.splash-content h1{font-size:1.6rem;color:#fff;text-transform:uppercase;letter-spacing:2px;margin-bottom:.5rem}.splash-content .subtitle{color:#ffffffb3;font-size:1rem}.splash-content .logo-placeholder{margin:0 auto 1rem}.gallery-header{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-bottom:1.25rem}.gallery-title{text-align:center;margin-bottom:0;color:var(--mackenzie-red);text-transform:uppercase;letter-spacing:2px}.refresh-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:none;border:2px solid var(--mackenzie-red);color:var(--mackenzie-red);cursor:pointer;transition:all .2s;flex-shrink:0}.refresh-btn:hover{background:var(--mackenzie-red);color:#fff}.refresh-btn:disabled{opacity:.5;cursor:not-allowed}.gallery-empty{text-align:center;padding:3rem 1rem;color:#666}.gallery-count{text-align:center;font-size:.8rem;color:#888;margin-bottom:1.25rem}.search-bar{display:flex;align-items:center;gap:.6rem;background:#fff;border:2px solid var(--mackenzie-red);padding:.6rem .85rem;margin-bottom:1.5rem}.search-bar svg{color:var(--mackenzie-red);flex-shrink:0}.search-bar input{flex:1;border:none;background:none;font-family:Courier New,Courier,monospace;font-size:.95rem;color:#333;outline:none}.search-bar input::placeholder{color:#aaa}.search-clear{background:none;border:none;font-size:1.3rem;color:#999;cursor:pointer;padding:0 .2rem;line-height:1}.search-clear:hover{color:var(--mackenzie-red)}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.5rem;margin-bottom:2rem}.gallery-card{background:#fff;border:3px solid var(--mackenzie-red);padding:1rem;transition:transform .3s,box-shadow .3s}.gallery-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px #e1001e33}.gallery-photos{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin-bottom:1rem}.gallery-photo{position:relative;aspect-ratio:3/4;overflow:hidden;background:var(--old-paper);border:2px solid var(--mackenzie-red)}.gallery-photo img{width:100%;height:100%;object-fit:cover}.gallery-photo-empty{display:flex;align-items:center;justify-content:center;color:#ccc}.gallery-photo-empty svg{opacity:.4}.photo-label{position:absolute;bottom:0;left:0;right:0;background:#e1001ee6;color:#fff;padding:.25rem;text-align:center;font-size:.7rem;font-weight:700;text-transform:uppercase}.gallery-info{text-align:center}.gallery-info h3{color:var(--mackenzie-red);font-size:1rem;margin-bottom:.25rem;text-transform:uppercase;letter-spacing:1px;line-height:1.2;padding-bottom:.8rem}.gallery-nickname{font-style:italic;color:#888;font-size:.9rem;margin-bottom:.3rem;font-weight:700}.gallery-profession{color:var(--mackenzie-red);font-size:.8rem;font-weight:700;margin-bottom:.2rem}.gallery-bio-wrap{margin-bottom:.3rem}.gallery-bio{color:#555;font-size:.85rem;font-weight:700;line-height:1.4;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.gallery-bio.gallery-bio-expanded{display:block;-webkit-line-clamp:unset;line-clamp:unset;-webkit-box-orient:unset;overflow:visible}.gallery-bio-toggle{margin-top:.25rem;padding:.15rem .4rem;font-family:inherit;font-size:.7rem;font-weight:600;color:var(--mackenzie-red);background:none;border:none;cursor:pointer;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.gallery-bio-toggle:hover{text-decoration:underline}.gallery-card-footer{margin-top:.75rem;padding-top:.6rem;border-top:1px solid rgba(225,0,30,.25);display:flex;flex-wrap:wrap;justify-content:center;gap:.75rem 1.25rem}.gallery-link{color:var(--mackenzie-red);font-weight:700;font-size:.8rem;text-decoration:none}.gallery-link:hover{text-decoration:underline}.group-gallery-admin-bar{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1rem;padding:.75rem;background:var(--old-paper-dark);border-radius:8px}.group-gallery-admin-input{position:absolute;width:.1px;height:.1px;opacity:0;overflow:hidden;z-index:-1}.group-gallery-admin-upload-btn{padding:.5rem 1rem;border-radius:8px;border:1px solid var(--ink);background:var(--cream);color:var(--ink);font-weight:600;cursor:pointer}.group-gallery-admin-upload-btn:hover:not(:disabled){background:var(--old-paper-dark)}.group-gallery-admin-upload-btn:disabled{opacity:.7;cursor:not-allowed}.group-gallery-admin-error{color:var(--error, #c00);font-size:.9rem;margin:0;width:100%}.group-gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.75rem;margin-bottom:2rem}.group-gallery-item-wrap{position:relative}.group-gallery-item{aspect-ratio:1;border:none;padding:0;border-radius:8px;overflow:hidden;background:var(--old-paper-dark);cursor:pointer;transition:transform .2s,box-shadow .2s;width:100%;display:block}.group-gallery-item:hover{transform:scale(1.02);box-shadow:0 4px 12px #00000026}.group-gallery-item img{width:100%;height:100%;object-fit:cover;display:block}.group-gallery-delete-btn{position:absolute;top:4px;right:4px;width:32px;height:32px;border:none;border-radius:6px;background:#000000a6;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:background .2s}.group-gallery-delete-btn:hover:not(:disabled){background:#b40000e6}.group-gallery-delete-btn:disabled{cursor:not-allowed;opacity:.8}.group-gallery-delete-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.lightbox-overlay{position:fixed;inset:0;background:#000000e6;z-index:9999;display:flex;align-items:center;justify-content:center;padding:1rem}.lightbox-content{max-width:100%;max-height:100%;display:flex;flex-direction:column;align-items:center}.lightbox-content img{max-width:100%;max-height:85vh;object-fit:contain;border-radius:4px}.lightbox-caption{color:#fff;margin-top:.75rem;font-size:.9rem;text-align:center}.lightbox-close{position:absolute;top:1rem;right:1rem;width:44px;height:44px;border:none;background:#fff3;color:#fff;font-size:1.75rem;line-height:1;cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center;padding:0}.lightbox-close:hover{background:#ffffff4d}.gallery-loading{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:3rem 1rem;color:#666}.gallery-spinner{width:36px;height:36px;border:4px solid var(--old-paper-dark);border-top:4px solid var(--mackenzie-red);border-radius:50%;animation:spin .8s linear infinite}.gallery-spinner-small{width:22px;height:22px;border:3px solid var(--old-paper-dark);border-top:3px solid var(--mackenzie-red);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.gallery-sentinel{min-height:40px;display:flex;align-items:center;justify-content:center}.gallery-loading-more{display:flex;align-items:center;gap:.6rem;padding:1rem 0;color:#888;font-size:.85rem}.gallery-end{text-align:center;padding:1rem 0 2rem;color:#888;font-size:.85rem}.has-bottom-nav{padding-bottom:0}.bottom-nav{display:none}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.2rem;padding:.6rem .25rem;background:none;border:none;color:#ffffffb3;font-family:Courier New,Courier,monospace;font-size:.65rem;cursor:pointer;transition:color .2s,background .2s}.bottom-nav-item:hover{color:#fff;background:#ffffff1a}.bottom-nav-item.active{color:#fff;background:#fff3;font-weight:700}.bottom-nav-icon{display:flex;align-items:center;justify-content:center;height:22px}@media(max-width:768px){.header-nav-desktop{display:none!important}.bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;background:var(--mackenzie-red);border-top:3px solid #b30018;padding:0;padding-bottom:env(safe-area-inset-bottom,0);z-index:100;box-shadow:0 -4px 12px #00000026}.has-bottom-nav{padding-bottom:calc(72px + env(safe-area-inset-bottom,0px))}.has-bottom-nav .footer{margin-bottom:0}.has-bottom-nav .login-container{margin-bottom:1rem}}@media(max-width:480px){.header-brand h1{font-size:1rem}.header-brand h2{font-size:.8rem}.header-centered h1{font-size:1.3rem}.header-centered h2{font-size:1rem}.photos-container{gap:.75rem}.photo-box h2{font-size:.7rem}.preview-content{flex-direction:column}.preview-photos{width:100%}.gallery-grid{grid-template-columns:1fr;gap:1rem}.form-row{grid-template-columns:1fr;gap:0}}
