*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--font: "Plus Jakarta Sans", ui-sans-serif, system-ui, -apple-system, sans-serif;--bg: #fafafa;--bg-card: #fff;--text: #1a1a1a;--text-muted: #6b7280;--border: #e5e7eb;--primary: #1a1a1a;--primary-hover: #333;--radius: .5rem;--radius-lg: .75rem;--shadow: 0 1px 3px rgb(0 0 0 / .08);--max-w: 1200px}html{font-family:var(--font);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}body{min-height:100dvh}a{color:inherit;text-decoration:none}button{font:inherit;cursor:pointer;border:none;background:none}img{display:block;max-width:100%}.container{width:100%;max-width:var(--max-w);margin:0 auto;padding:1.5rem 1rem}.pw-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:80dvh;gap:1.5rem;text-align:center}.pw-screen h1{font-size:1.5rem;font-weight:600}.pw-screen .preview-img{width:100%;max-width:20rem;border-radius:var(--radius-lg);border:1px solid var(--border);object-fit:cover}.pw-form{display:flex;flex-direction:column;gap:.75rem;width:100%;max-width:20rem}.pw-form input{font:inherit;padding:.625rem .875rem;border:1px solid var(--border);border-radius:var(--radius);font-size:1rem;text-align:center;letter-spacing:.15em;outline:none;transition:border-color .15s}.pw-form input:focus{border-color:var(--primary)}.pw-form button,.btn{padding:.625rem 1.25rem;background:var(--primary);color:#fff;border-radius:var(--radius);font-weight:500;font-size:.9rem;transition:background .15s,opacity .15s}.pw-form button:hover,.btn:hover{background:var(--primary-hover)}.pw-form button:disabled,.btn:disabled{opacity:.5;cursor:not-allowed}.pw-error{color:#dc2626;font-size:.85rem}.gallery-header{text-align:center;margin-bottom:2rem}.gallery-header h1{font-size:1.75rem;font-weight:600;margin-bottom:.25rem}.gallery-header .date{color:var(--text-muted);font-size:.9rem}.section-tabs{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center;margin-bottom:1.5rem;position:sticky;top:0;z-index:5;background:var(--bg);padding-top:.5rem;padding-bottom:.5rem}.section-tab{padding:.4rem 1rem;border-radius:999px;font-size:.85rem;font-weight:500;color:var(--text-muted);border:1px solid var(--border);background:var(--bg-card);transition:background .15s,color .15s}.section-tab:hover{background:var(--border)}.section-tab[data-active=true]{background:var(--primary);color:#fff;border-color:var(--primary)}.gallery-section{margin-bottom:.5rem}.section-heading{font-size:1.25rem;font-weight:600;margin:1.5rem 0 .75rem}.section-heading-card{display:flex;align-items:flex-end;aspect-ratio:1;padding:1rem;border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--bg-card);margin-bottom:.5rem}.section-heading-card h2{font-size:clamp(1.75rem,6vw,3.25rem);font-weight:700;line-height:1.05;letter-spacing:-.01em;word-break:break-word;-webkit-hyphens:auto;hyphens:auto}.image-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}@media(min-width:640px){.image-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:480px){.image-grid{gap:.25rem}.section-heading-card{display:none}}@media(max-width:640px){.section-tabs{display:none}.section-tab{padding:.25rem .6rem;font-size:.75rem}}.image-cell{aspect-ratio:1;overflow:hidden;border-radius:var(--radius);cursor:zoom-in;position:relative;background:var(--border)}.image-cell img{width:100%;height:100%;object-fit:cover;transition:filter .2s}.image-cell:hover img{filter:brightness(1.08)}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;animation:fade-in .2s;touch-action:none}@keyframes fade-in{0%{opacity:0}}.lightbox-strip-top{position:absolute;top:0;left:0;right:0;height:3.5rem;background:#fff;display:flex;align-items:center;justify-content:flex-end;gap:.5rem;padding:0 1rem;z-index:102;flex-shrink:0;transition:opacity .3s ease}.lightbox-strip-bottom{position:absolute;bottom:0;left:0;right:0;height:3.5rem;background:#fff;display:flex;align-items:center;justify-content:space-between;padding:0 1rem;z-index:102;flex-shrink:0;transition:opacity .3s ease}.lightbox-strip--hidden{opacity:0;pointer-events:none}.lightbox-image-area{position:absolute;top:3.5rem;left:0;right:0;bottom:3.5rem;overflow:hidden}.lightbox-slider{display:flex;align-items:center;width:100%;height:100%;will-change:transform}.lightbox-slide{flex:0 0 100%;width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:0 .5rem}.lightbox-slide--prev{margin-left:-100%}.lightbox-slide img{max-width:100%;max-height:100%;object-fit:contain;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;pointer-events:none}.lightbox-strip-top button,.lightbox-strip-bottom button{cursor:pointer;position:relative;z-index:1}.lightbox--fullscreen .lightbox-image-area{top:0;left:0;right:0;bottom:0}.lightbox--fullscreen .lightbox-slide{padding:0}.lightbox--fullscreen .lightbox-slide img{width:100%;height:100%;object-fit:contain;object-position:center}.lightbox--fullscreen .lightbox-strip-top,.lightbox--fullscreen .lightbox-strip-bottom{background:#ffffff40;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}@keyframes lightbox-image-fade{0%{opacity:0}to{opacity:1}}@media(min-width:641px){.lightbox-slide--current img{animation:lightbox-image-fade .2s ease-in-out}}.lightbox-close{color:var(--text);padding:.5rem;opacity:.8;transition:opacity .15s;background:none;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center}.lightbox-close:hover{opacity:1}.lightbox-close svg{width:1.5rem;height:1.5rem}.lightbox-bottom-left{display:flex;align-items:center;gap:.75rem}.lightbox-bottom-right{display:flex;align-items:center;gap:.5rem}.lightbox-icon-btn{color:var(--text);padding:.5rem;opacity:.8;transition:opacity .15s;background:none;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center}.lightbox-icon-btn:hover{opacity:1}.lightbox-icon-btn:disabled{opacity:.5;cursor:not-allowed}.lightbox-icon-btn svg{width:1.5rem;height:1.5rem}#lightbox-share svg{width:1.35rem;height:1.35rem}#lightbox-fullscreen svg{width:1.35rem;height:1.35rem}.lightbox-counter{color:var(--text-muted);font-size:.9rem}.lightbox-nav-arrow{color:var(--text);padding:.5rem;opacity:.8;transition:opacity .15s;background:none;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center}.lightbox-nav-arrow:hover{opacity:1}.lightbox-nav-arrow svg{width:1.5rem;height:1.5rem}@media(min-width:641px){.lightbox-nav-arrow{display:flex}}@media(max-width:640px){.lightbox-nav-arrow{display:none}}.photographer-footer{margin-top:3rem;padding-top:2rem;border-top:1px solid var(--border);display:flex;flex-direction:column;align-items:center;gap:.75rem;text-align:center}.photographer-footer .avatar{width:4rem;height:4rem;border-radius:50%;object-fit:cover;border:2px solid var(--border)}.photographer-footer .name{font-weight:600;font-size:1rem}.photographer-footer .tagline{color:var(--text-muted);font-size:.85rem}.photographer-footer a{color:var(--primary);font-size:.85rem}.loader{display:flex;align-items:center;justify-content:center;min-height:40dvh;color:var(--text-muted);font-size:.9rem}.spinner{width:1.5rem;height:1.5rem;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .6s linear infinite;margin-right:.5rem}@keyframes spin{to{transform:rotate(360deg)}}.hidden{display:none!important}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
