@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600&display=swap";
*{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{color:#e8eaed;background:linear-gradient(135deg,#1a1f2e 0%,#1f2433 25%,#242938 50%,#292e3d 75%,#2d3548 100%) 0 0/cover no-repeat fixed;min-height:100vh;margin:0;padding:0;font-family:Inter,system-ui,sans-serif;line-height:1.6;overflow-x:hidden}main{width:100%;position:relative}a{color:inherit;text-decoration:none;transition:color .2s}a:hover{color:#7eb8b8}header{align-items:flex-start;gap:1.75rem;margin-bottom:3rem;display:flex}#avatar{border:3px solid #7eb8b84d;border-radius:50%;flex-shrink:0;width:110px;height:110px}.intro{padding-top:.25rem}.greeting{color:#9aa0a6;margin-bottom:.25rem;font-size:.875rem;font-weight:400}h1{letter-spacing:-.02em;margin-bottom:.5rem;font-size:2.75rem;font-weight:600;line-height:1.1}.tagline{color:#9aa0a6;font-size:.95rem}.experience{border-left:2px solid #7eb8b840;flex-direction:column;gap:1.5rem;margin-bottom:2.5rem;padding-left:.5rem;display:flex}.role{gap:1.25rem;padding-left:1rem;display:flex}.year{color:#7eb8b8;min-width:90px;padding-top:.15rem;font-size:.8rem;font-weight:500}.details h3{margin-bottom:.25rem;font-size:1rem;font-weight:500}.details p{color:#9aa0a6;font-size:.875rem;line-height:1.5}.details .clients{color:#6b7280;margin-top:.35rem;font-size:.75rem}.links{justify-content:space-between;align-items:center;padding-left:.5rem;display:flex;position:relative}.links-main{gap:1.5rem;display:flex}.links-admin{opacity:0;align-items:center;gap:1rem;transition:opacity .3s ease-in-out,transform .3s ease-in-out;display:flex;transform:translate(50px)}.links-admin.visible{opacity:1;transform:translate(0)}.links-main.gallery-mode .link-photography:after{width:100%}.user-greeting{color:#9aa0a6;font-size:.875rem;font-weight:400}.links a{color:#9aa0a6;align-items:center;gap:.4rem;font-size:.875rem;font-weight:400;display:inline-flex;position:relative}.links a svg{flex-shrink:0}.links a:after{content:"";background:#7eb8b8;width:0;height:1px;transition:width .2s;position:absolute;bottom:-2px;left:0}.links a:hover{color:#e8eaed}.links a:hover:after{width:100%}.link-admin{color:#9aa0a6;opacity:.6;font-size:.875rem;font-weight:400}@keyframes slideOutLeft{to{opacity:0;transform:translate(-100px)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-100px)}to{opacity:1;transform:translate(0)}}.upload-section{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff0d;border:1px solid #7eb8b833;border-radius:8px;margin-top:1.5rem;padding:1.5rem 1.5rem 1.5rem 1rem;display:block}.intro-section{flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:2rem 2rem 6rem;display:flex;position:relative}.intro-content{width:100%;max-width:520px;margin-bottom:3rem;position:relative}.scroll-hint{opacity:.6;cursor:pointer;border-radius:8px;flex-direction:column;align-items:center;gap:.5rem;padding:.5rem;transition:all .2s;display:flex;position:absolute;bottom:2rem}.scroll-hint:hover{opacity:1;transform:translateY(-2px)}.scroll-hint-text{color:#9aa0a6;letter-spacing:.5px;text-transform:uppercase;font-size:.75rem;font-weight:400;transition:color .2s}.scroll-hint-arrow{color:#7eb8b8;font-size:1.25rem;transition:color .2s}.scroll-hint:hover .scroll-hint-text{color:#e8eaed}.scroll-hint:hover .scroll-hint-arrow{color:#9acaca}@media (max-height:600px){.scroll-hint{display:none}.intro-section{padding-bottom:2rem}}.gallery-section{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0000004d;justify-content:center;min-height:100vh;padding:4rem 2rem;display:flex}.gallery-content{flex-direction:column;gap:2rem;width:100%;max-width:1200px;display:flex}.current-year-header{border-bottom:2px solid #7eb8b840;margin-bottom:1rem;padding:.5rem 0 .5rem 1rem}.gallery-scroll-container{max-height:none;margin:0;padding:0;overflow-y:visible}@media (max-width:540px){.intro-section,.gallery-section{padding:1rem}.intro-section{padding-bottom:5rem}.scroll-hint{bottom:1rem}header{text-align:center;flex-direction:column;align-items:center}h1{font-size:2.25rem}.experience{border-left:none;padding-left:0}.role{flex-direction:column;gap:.25rem;padding-left:0}.year{min-width:auto}.links{flex-direction:column;gap:1rem;padding-left:0}.links-main,.links-admin{justify-content:center}.gallery-grid{grid-template-columns:repeat(3,1fr)}.upload-form-row{grid-template-columns:1fr;gap:1rem}}.gallery-page{justify-content:center;align-items:center;padding:2rem}.gallery-main{flex-direction:column;width:100%;max-width:520px;height:90vh;display:flex}.gallery-profile{flex-shrink:0;margin-bottom:2.5rem}.gallery-header-top{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.admin-controls{align-items:center;gap:12px;display:flex}.user-greeting{color:#9aa0a6;font-size:.875rem}.logout-btn,.login-btn{color:#e8eaed;background:#dc3545cc;border:1px solid #dc35454d;border-radius:6px;padding:6px 12px;font-size:14px;text-decoration:none;transition:all .2s}.logout-btn:hover,.login-btn:hover{background:#dc3545;border-color:#dc354580}.back-link{color:#9aa0a6;align-items:center;gap:.25rem;font-size:.875rem;display:inline-flex}.back-link:hover{color:#e8eaed}.gallery-intro-section{align-items:flex-start;gap:1.75rem;margin-bottom:2rem;display:flex}#gallery-avatar{border:3px solid #7eb8b84d;border-radius:50%;flex-shrink:0;width:110px;height:110px}.gallery-intro{padding-top:.25rem}.gallery-intro .greeting{color:#9aa0a6;margin-bottom:.25rem;font-size:.875rem;font-weight:400}.gallery-intro h1{letter-spacing:-.02em;margin-bottom:.5rem;font-size:2.75rem;font-weight:600;line-height:1.1}.gallery-intro .tagline{color:#9aa0a6;font-size:.95rem}.upload-section{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff0d;border:1px solid #7eb8b833;border-radius:8px;margin-top:1.5rem;padding:1.5rem}.upload-section h3{color:#e8eaed;margin:0 0 1rem;font-size:1rem;font-weight:500}.upload-form-row{grid-template-columns:1fr auto auto auto;align-items:end;gap:1rem;display:grid}.upload-section .form-group{margin:0}.upload-section label{color:#9aa0a6;margin-bottom:5px;font-size:.875rem;font-weight:500;display:block}.upload-section input{color:#e8eaed;background:#ffffff1a;border:1px solid #7eb8b84d;border-radius:6px;width:100%;padding:8px 12px;font-size:14px;transition:all .2s}.upload-section input:focus{background:#ffffff26;border-color:#7eb8b8;outline:none;box-shadow:0 0 0 2px #7eb8b833}.upload-section input::placeholder{color:#9aa0a6}#upload-btn{color:#e8eaed;cursor:pointer;white-space:nowrap;background:#7eb8b8cc;border:1px solid #7eb8b84d;border-radius:6px;padding:10px 16px;font-size:14px;font-weight:500;transition:all .2s}#upload-btn:hover{background:#7eb8b8}#upload-btn:disabled{cursor:not-allowed;background:#6b728080}.upload-progress{margin-top:1rem}.progress-bar{background:#0003;border-radius:3px;width:100%;height:6px;margin-bottom:8px;overflow:hidden}.progress-fill{background:#7eb8b8;width:0%;height:100%;transition:width .3s}.progress-text{color:#9aa0a6;font-size:13px}.message{border-left:3px solid;border-radius:6px;margin-bottom:1rem;padding:8px 12px;font-size:14px}.message.success{color:#7eb8b8;background:#28a74526;border-left-color:#7eb8b8}.message.error{color:#ff6b7a;background:#dc354526;border-left-color:#ff6b7a}.gallery-content{flex-direction:column;flex:1;min-height:0;display:flex}.current-year-header{border-bottom:2px solid #7eb8b840;flex-shrink:0;margin-bottom:1.5rem;padding:.5rem 0}.current-year-header h2{color:#e8eaed;margin:0;padding-left:0;font-size:1.5rem;font-weight:600}.gallery-scroll-container{flex:1;margin-right:-.5rem;padding-right:.5rem;overflow-y:auto}.gallery-scroll-container::-webkit-scrollbar{width:6px}.gallery-scroll-container::-webkit-scrollbar-track{background:#ffffff1a;border-radius:3px}.gallery-scroll-container::-webkit-scrollbar-thumb{background:#7eb8b880;border-radius:3px}.gallery-scroll-container::-webkit-scrollbar-thumb:hover{background:#7eb8b8b3}.year-section{margin-bottom:2rem}.year-header{color:#e8eaed;border-bottom:1px solid #7eb8b833;margin:0 0 1rem;padding-bottom:.5rem;font-size:1.25rem;font-weight:600}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem;display:grid}.gallery-item{cursor:pointer;aspect-ratio:1;background:#0003;border-radius:6px;position:relative;overflow:hidden}.gallery-item img{object-fit:cover;opacity:.9;width:100%;height:100%;transition:transform .3s,opacity .3s}.gallery-item:hover img{opacity:1;transform:scale(1.05)}.photo-info{opacity:0;box-sizing:border-box;background:linear-gradient(#0000 0%,#0009 60%,#000c 100%);flex-direction:column;gap:.15rem;margin:0;padding:1rem .75rem .875rem;transition:all .3s;display:flex;position:absolute;bottom:-1px;left:0;right:0;transform:translateY(15px)}.gallery-item:hover .photo-info{opacity:1;transform:translateY(0)}.photo-info .location{color:#e8eaed;font-size:.75rem;font-weight:500;line-height:1.2}.photo-info .date{color:#9aa0a6;font-size:.65rem}.delete-photo-btn{color:#e8eaed;cursor:pointer;opacity:0;z-index:10;background:#dc3545e6;border:none;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;transition:all .2s;display:flex;position:absolute;top:6px;right:6px;transform:scale(.8)}.gallery-item:hover .delete-photo-btn{opacity:1;transform:scale(1)}.delete-photo-btn:hover{background:#dc3545;transform:scale(1.1)}.delete-photo-btn svg{width:12px;height:12px}@media (max-width:768px){.gallery-intro-section{text-align:center;flex-direction:column;align-items:center}.gallery-intro h1{font-size:2.25rem}.gallery-grid{grid-template-columns:repeat(4,1fr)}.gallery-header-top{flex-direction:column;align-items:flex-start;gap:.75rem}.admin-controls{align-self:flex-end}.upload-form-row{grid-template-columns:1fr;gap:1rem}}@media (max-width:480px){.gallery-grid{grid-template-columns:repeat(3,1fr)}.gallery-intro h1{font-size:1.75rem}.current-year-header h2{font-size:1.25rem}}.lightbox{opacity:0;visibility:hidden;z-index:1000;cursor:pointer;background:#000000f2;justify-content:center;align-items:center;transition:opacity .3s,visibility .3s;display:flex;position:fixed;inset:0}.lightbox.active{opacity:1;visibility:visible}.lightbox-image-container{justify-content:center;align-items:center;display:flex;position:relative}.lightbox-img{object-fit:contain;cursor:default;flex-shrink:1;max-width:90vw;max-height:calc(90vh - 5rem)}.lightbox-close{color:#fff;cursor:pointer;opacity:.9;z-index:10;background:#00000080;border:none;border-radius:50%;justify-content:center;align-items:center;width:2.5rem;height:2.5rem;font-size:2rem;line-height:1;transition:opacity .2s,background .2s;display:flex;position:absolute;top:1rem;right:1.5rem}.lightbox-close:hover{opacity:1;background:#000c}.lightbox-content{flex-direction:column;justify-content:center;align-items:center;gap:0;max-width:90vw;height:100vh;max-height:90vh;display:flex}.lightbox-metadata{color:#fff;z-index:2;background:#000000b3;border-radius:.5rem;justify-content:space-between;align-items:center;gap:1rem;padding:.75rem 0;font-size:.875rem;display:flex;position:absolute;top:0;left:0;right:0;transform:translateY(-100%)}.lightbox-location{margin-left:0;font-weight:600}.lightbox-date{opacity:.8}.lightbox-counter{opacity:.7;margin-left:auto;margin-right:0;font-size:.75rem}.lightbox-nav{color:#fff;cursor:pointer;opacity:.9;z-index:10;background:#000000b3;border:none;border-radius:50%;justify-content:center;align-items:center;width:3rem;height:3rem;font-size:2rem;line-height:1;transition:opacity .2s,background .2s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.lightbox-nav:hover{opacity:1;background:#000000e6}.lightbox-prev{left:2rem}.lightbox-next{right:2rem}@media (max-width:768px){.lightbox-img{max-width:100vw;max-height:calc(85vh - 5rem)}.lightbox-close{background:#000000b3;width:2.5rem;height:2.5rem;font-size:1.5rem;top:.75rem;right:.75rem}.lightbox-metadata{text-align:center;flex-direction:column;gap:.5rem;font-size:.75rem}.lightbox-location{margin-left:0}.lightbox-counter{margin-left:0;margin-right:0;font-size:.625rem}.lightbox-nav{opacity:1;width:2.5rem;height:2.5rem;font-size:1.5rem}.lightbox-prev{left:.5rem}.lightbox-next{right:.5rem}}.auth-nav.top-auth{z-index:100;transition:all .3s;position:fixed;top:2rem;right:2rem}.auth-controls{align-items:center;gap:1rem;display:flex}.auth-nav.top-auth .auth-controls{opacity:0;transition:all .3s;transform:translate(20px)}.auth-nav.top-auth .auth-controls.logged-in,.auth-nav.top-auth:hover .auth-controls{opacity:1;transform:translate(0)}.auth-nav.top-auth:before{content:"";z-index:-1;position:absolute;inset:-10px -10px -10px -50px}.auth-link{color:#9aa0a6;opacity:.8;white-space:nowrap;align-items:center;gap:.4rem;font-size:.875rem;font-weight:400;transition:all .2s;display:inline-flex;position:relative}.auth-link svg{flex-shrink:0}.auth-link:hover{color:#e8eaed;opacity:1}.auth-link:after{content:"";background:#7eb8b8;width:0;height:1px;transition:width .2s;position:absolute;bottom:-2px;left:0}.auth-link:hover:after{width:100%}.upload-btn{cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;margin:0;padding:0;transition:all .2s;display:flex}.upload-btn:hover{background:#7eb8b81a;transform:scale(1.1)}.upload-btn:after{display:none}.upload-modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000c;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.upload-modal{background:linear-gradient(135deg,#1a1f2e 0%,#1f2433 25%,#242938 50%,#292e3d 75%,#2d3548 100%);border:1px solid #7eb8b84d;border-radius:12px;width:90vw;max-width:500px;max-height:90vh;padding:2rem;overflow-y:auto;box-shadow:0 20px 40px #00000080}.upload-modal-header{border-bottom:1px solid #7eb8b833;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;display:flex}.upload-modal-header h3{color:#e8eaed;margin:0;font-size:1.25rem;font-weight:600}.modal-close-btn{color:#9aa0a6;cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:.5rem;transition:all .2s;display:flex}.modal-close-btn:hover{color:#ff6b7a;background:#dc35451a}.modal-form-group{margin-bottom:1.5rem}.modal-form-group label{color:#9aa0a6;margin-bottom:.5rem;font-size:.875rem;font-weight:500;display:block}.modal-form-group input{color:#e8eaed;background:#ffffff1a;border:1px solid #7eb8b84d;border-radius:8px;width:100%;padding:.75rem;font-size:14px;transition:all .2s}.modal-form-group input:focus{background:#ffffff26;border-color:#7eb8b8;outline:none;box-shadow:0 0 0 3px #7eb8b833}.modal-form-group input::placeholder{color:#9aa0a6}.modal-form-actions{border-top:1px solid #7eb8b833;justify-content:flex-end;gap:1rem;margin-top:2rem;padding-top:1rem;display:flex}.modal-cancel-btn,.modal-upload-btn{cursor:pointer;border:1px solid #0000;border-radius:8px;padding:.75rem 1.5rem;font-size:14px;font-weight:500;transition:all .2s}.modal-cancel-btn{color:#9aa0a6;background:#6b728033;border-color:#6b72804d}.modal-cancel-btn:hover{color:#e8eaed;background:#6b72804d}.modal-upload-btn{color:#e8eaed;background:#7eb8b8cc;border-color:#7eb8b84d}.modal-upload-btn:hover:not(:disabled){background:#7eb8b8}.modal-upload-btn:disabled{color:#e8eaed80;cursor:not-allowed;background:#6b728080}
