*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}:root,[data-theme=light]{--color-bg:#f9f6f0;--color-surface:#fffefa;--color-surface-2:#fff8f2;--color-surface-offset:#f2ede6;--color-border:#3c28141f;--color-text:#2a2118;--color-text-muted:#7a6b60;--color-text-faint:#b8a898;--color-primary:#b05e68;--color-primary-hover:#903848;--color-primary-highlight:#f3dde0;--color-divider:#3c281414;--color-error:#c0392b;--color-success:#27ae60;--shadow-card:0 1px 3px #3c28140f, 0 4px 12px #3c28140a;--shadow-elevated:0 4px 20px #3c28141a}[data-theme=dark]{--color-bg:#1a1614;--color-surface:#201c1a;--color-surface-2:#252018;--color-surface-offset:#1e1a18;--color-border:#ffdcc81a;--color-text:#e8e0d8;--color-text-muted:#a09080;--color-text-faint:#685850;--color-primary:#d4848e;--color-primary-hover:#e8a0a8;--color-primary-highlight:#3a2028;--color-divider:#ffdcc80f;--color-error:#e74c3c;--color-success:#2ecc71;--shadow-card:0 1px 3px #0003, 0 4px 12px #00000026;--shadow-elevated:0 4px 20px #0000004d}:root{--font-display:"Cormorant Garamond", Georgia, serif;--font-body:"Inter", "Helvetica Neue", sans-serif;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-full:9999px;--transition-fast:.15s ease;--transition-base:.22s ease;--transition-slow:.35s ease;--ease-out-expo:cubic-bezier(.16, 1, .3, 1);--max-width:1080px;--nav-height:60px}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}body{font-family:var(--font-body);color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased;min-height:100dvh;font-size:16px;line-height:1.55}.app-nav{z-index:100;background:var(--color-surface);border-bottom:1px solid var(--color-border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);height:var(--nav-height);position:sticky;top:0}.nav-inner{max-width:var(--max-width);align-items:center;gap:8px;height:100%;margin:0 auto;padding:0 16px;display:flex}.nav-brand{color:var(--color-text);flex-shrink:1;align-items:center;gap:10px;min-width:0;text-decoration:none;display:flex}.nav-brand svg{flex-shrink:0}.nav-brand-text{font-family:var(--font-display);letter-spacing:.01em;white-space:nowrap;text-overflow:ellipsis;font-size:20px;font-weight:500;overflow:hidden}.nav-tabs{flex-shrink:0;align-items:center;gap:2px;margin-left:auto;display:flex}.nav-tab{border-radius:var(--radius-full);color:var(--color-text-muted);cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast);white-space:nowrap;background:0 0;border:none;align-items:center;gap:6px;padding:8px 14px;font-size:14px;font-weight:450;text-decoration:none;display:flex}.nav-tab svg{flex-shrink:0;width:18px;height:18px}.nav-tab:hover{background:var(--color-surface-offset);color:var(--color-text)}.nav-tab.active{background:var(--color-primary-highlight);color:var(--color-primary);font-weight:500}.theme-toggle{border-radius:var(--radius-full);cursor:pointer;width:36px;height:36px;color:var(--color-text-muted);transition:background var(--transition-fast), color var(--transition-fast);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.theme-toggle:hover{background:var(--color-surface-offset);color:var(--color-text)}.theme-toggle svg{width:18px;height:18px}@media (width<=540px){.app-nav{height:auto}.nav-inner{flex-wrap:wrap;gap:0;padding:10px 12px 6px}.nav-brand{order:1}.theme-toggle{order:2;width:32px;height:32px;margin-left:auto}.nav-tabs{border-top:1px solid var(--color-divider);order:3;justify-content:center;gap:4px;width:100%;margin-top:8px;margin-left:0;padding-top:8px}.nav-tab{flex:1;justify-content:center;padding:7px 0;font-size:13px}}.app-main{max-width:var(--max-width);margin:0 auto;padding:24px 16px 80px}.view{display:none}.view.active{display:block}.section-header{text-align:center;margin-bottom:28px}.section-header h1{font-family:var(--font-display);color:var(--color-text);margin-bottom:6px;font-size:clamp(28px,5vw,38px);font-weight:500}.section-header p{color:var(--color-text-muted);font-size:15px}.btn{border-radius:var(--radius-md);font-family:var(--font-body);cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast), transform var(--transition-fast), opacity var(--transition-fast);white-space:nowrap;border:none;justify-content:center;align-items:center;gap:8px;min-height:48px;padding:12px 24px;font-size:15px;font-weight:500;display:inline-flex}.btn:active{transform:scale(.97)}.btn-primary{background:var(--color-primary);color:#fff;width:100%}.btn-primary:hover{background:var(--color-primary-hover)}.btn-primary:disabled{opacity:.45;cursor:not-allowed;transform:none}.btn-secondary{background:var(--color-surface-offset);color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-surface-2)}.btn-danger{background:var(--color-error);color:#fff}.btn-danger:hover{opacity:.85}.btn-ghost{color:var(--color-text-muted);background:0 0;padding:8px 14px}.btn-ghost:hover{background:var(--color-surface-offset);color:var(--color-text)}.btn svg{width:18px;height:18px}.upload-success{text-align:center;padding:48px 20px}.upload-success svg{width:56px;height:56px;color:var(--color-success);margin-bottom:16px}.upload-success h2{font-family:var(--font-display);margin-bottom:8px;font-size:26px;font-weight:500}.upload-success p{color:var(--color-text-muted);margin-bottom:24px}.skeleton-grid{columns:3 260px;column-gap:12px}.skeleton-card{break-inside:avoid;border-radius:var(--radius-md);background:var(--color-surface);margin-bottom:12px;overflow:hidden}.skeleton-img{background:linear-gradient(90deg, var(--color-surface-offset) 25%, var(--color-surface) 50%, var(--color-surface-offset) 75%);background-size:200% 100%;width:100%;animation:1.5s ease-in-out infinite shimmer}.skeleton-line{background:linear-gradient(90deg, var(--color-surface-offset) 25%, var(--color-surface) 50%, var(--color-surface-offset) 75%);background-size:200% 100%;border-radius:4px;height:12px;margin:10px 12px;animation:1.5s ease-in-out infinite shimmer}.skeleton-line:last-child{width:60%;margin-bottom:12px}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.empty-state{text-align:center;color:var(--color-text-muted);flex-direction:column;align-items:center;padding:60px 20px;display:flex}.empty-state svg{width:56px;height:56px;color:var(--color-text-faint);margin-bottom:16px}.empty-state h3{font-family:var(--font-display);color:var(--color-text);margin-bottom:6px;font-size:24px;font-weight:500}.empty-state p{max-width:36ch;margin-bottom:20px}.modal-overlay{z-index:2000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;justify-content:center;align-items:center;padding:20px;display:none;position:fixed;inset:0}.modal-overlay.open{display:flex}.modal{background:var(--color-surface);border-radius:var(--radius-lg);width:100%;max-width:400px;box-shadow:var(--shadow-elevated);text-align:center;padding:28px}.modal h3{font-family:var(--font-display);margin-bottom:8px;font-size:20px;font-weight:500}.modal p{color:var(--color-text-muted);margin-bottom:24px;font-size:14px}.modal-actions{justify-content:center;gap:10px;display:flex}.modal-actions .btn{flex:1}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.skip-link{background:var(--color-primary);color:#fff;border-radius:var(--radius-md);z-index:9999;padding:10px 18px;font-size:14px;font-weight:500;text-decoration:none;transition:top .15s;position:absolute;top:-100%;left:16px}.skip-link:focus{top:12px}.hidden{display:none!important}.back-to-top{border-radius:var(--radius-full);background:var(--color-surface);border:1px solid var(--color-border);width:44px;height:44px;box-shadow:var(--shadow-elevated);color:var(--color-text-muted);cursor:pointer;opacity:0;pointer-events:none;transition:opacity var(--transition-base), background var(--transition-fast), color var(--transition-fast);z-index:50;justify-content:center;align-items:center;display:flex;position:fixed;bottom:24px;right:24px}.back-to-top.visible{opacity:1;pointer-events:auto}.back-to-top:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.back-to-top svg{width:22px;height:22px}.gallery-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.photo-count{color:var(--color-text-muted);font-size:14px}.filter-bar{flex-wrap:wrap;gap:6px;margin-bottom:20px;display:flex}.filter-chip{border-radius:var(--radius-full);cursor:pointer;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-muted);transition:all var(--transition-fast);align-items:center;gap:4px;padding:6px 14px;font-size:13px;font-weight:450;display:inline-flex}.filter-chip:hover{border-color:var(--color-primary);color:var(--color-primary)}.filter-chip.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.gallery-grid{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}@media (width<=800px){.gallery-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=540px){.gallery-grid{grid-template-columns:1fr}}.gallery-item{border-radius:var(--radius-md);background:var(--color-surface);cursor:pointer;transition:opacity var(--transition-base), transform var(--transition-base);animation:cardFadeIn .35s var(--ease-out-expo) backwards;overflow:hidden}.gallery-item img,.gallery-item video{aspect-ratio:3/4;object-fit:cover;width:100%;display:block}.video-still-wrap{background:var(--color-surface-offset);width:100%;position:relative}.video-still-wrap video{width:100%;min-height:120px;display:block}.gallery-video-badge{border-radius:var(--radius-full);color:#fff;pointer-events:none;background:#0000008c;justify-content:center;align-items:center;width:36px;height:36px;display:flex;position:absolute;top:10px;left:10px}.gallery-video-badge svg{width:16px;height:16px}.gallery-item{position:relative}.gallery-item-body{padding:10px 12px}.gallery-item-caption{color:var(--color-text);margin-bottom:6px;font-size:14px;line-height:1.45}.gallery-item-tags{flex-wrap:wrap;gap:4px;display:flex}.gallery-item-tag{border-radius:var(--radius-full);background:var(--color-primary-highlight);color:var(--color-primary);cursor:pointer;font-size:12px;font-family:var(--font-body);transition:background var(--transition-fast);border:none;padding:2px 8px}.gallery-item-tag:hover{background:var(--color-primary);color:#fff}.gallery-item-time{color:var(--color-text-faint);margin-top:4px;font-size:12px}@keyframes cardFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.gallery-loading-more{justify-content:center;padding:32px 0;display:flex}.gallery-loading-more .spinner{border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:28px;height:28px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.gallery-end{text-align:center;color:var(--color-text-faint);padding:32px 0;font-size:14px}.upload-zone{border:2px dashed var(--color-border);border-radius:var(--radius-lg);text-align:center;cursor:pointer;transition:border-color var(--transition-fast), background var(--transition-fast);background:var(--color-surface);flex-direction:column;justify-content:center;align-items:center;gap:10px;min-height:180px;padding:40px 20px;display:flex}.upload-zone:hover,.upload-zone.drag-over{border-color:var(--color-primary);background:var(--color-primary-highlight)}.upload-zone svg{width:40px;height:40px;color:var(--color-text-faint)}.upload-zone-text{color:var(--color-text-muted);font-size:15px}.upload-zone-hint{color:var(--color-text-faint);font-size:13px}.upload-zone input[type=file]{display:none}.preview-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;margin-top:16px;display:grid}.preview-card{border-radius:var(--radius-md);background:var(--color-surface-offset);border:1px solid var(--color-border);position:relative;overflow:hidden}.preview-card img,.preview-card video{aspect-ratio:1;object-fit:cover;width:100%;display:block}.preview-video-badge{border-radius:var(--radius-full);color:#fff;pointer-events:none;background:#0009;align-items:center;gap:4px;padding:3px 8px;font-size:11px;font-weight:500;display:flex;position:absolute;bottom:32px;left:8px}.preview-video-badge svg{width:12px;height:12px}.preview-card-info{color:var(--color-text-muted);white-space:nowrap;text-overflow:ellipsis;padding:6px 8px;font-size:12px;overflow:hidden}.preview-card-remove{border-radius:var(--radius-full);color:#fff;cursor:pointer;width:28px;height:28px;transition:background var(--transition-fast);background:#0000008c;border:none;justify-content:center;align-items:center;display:flex;position:absolute;top:6px;right:6px}.preview-card-remove:hover{background:var(--color-error)}.preview-card-remove svg{width:16px;height:16px}.preview-card-error{background:var(--color-error);color:#fff;text-align:center;padding:4px 8px;font-size:11px;position:absolute;bottom:0;left:0;right:0}.preview-card .progress-bar-wrap{background:#00000026;height:4px;position:absolute;bottom:0;left:0;right:0}.preview-card .progress-bar-fill{background:var(--color-primary);width:0%;height:100%;transition:width .2s}.form-group{margin-top:20px}.form-label{color:var(--color-text);margin-bottom:6px;font-size:14px;font-weight:500;display:block}.form-textarea{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);width:100%;min-height:80px;color:var(--color-text);font-family:var(--font-body);resize:vertical;transition:border-color var(--transition-fast);padding:12px;font-size:16px;line-height:1.5}.form-textarea:focus{border-color:var(--color-primary);outline:none}.char-count{text-align:right;color:var(--color-text-faint);margin-top:4px;font-size:12px}.char-count.warning{color:var(--color-error)}.tag-input-wrap{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);cursor:text;min-height:48px;transition:border-color var(--transition-fast);flex-wrap:wrap;align-items:center;gap:6px;padding:8px 12px;display:flex}.tag-input-wrap:focus-within{border-color:var(--color-primary)}.tag-input{min-width:80px;color:var(--color-text);font-size:16px;font-family:var(--font-body);background:0 0;border:none;outline:none;flex:1}.tag-pill{border-radius:var(--radius-full);background:var(--color-primary-highlight);color:var(--color-primary);white-space:nowrap;align-items:center;gap:4px;padding:4px 10px;font-size:13px;font-weight:500;display:inline-flex}.tag-pill button{cursor:pointer;color:var(--color-primary);border-radius:var(--radius-full);width:18px;height:18px;transition:background var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;padding:0;display:flex}.tag-pill button:hover{background:#00000014}.tag-pill button svg{width:14px;height:14px}.tag-suggestions{flex-wrap:wrap;gap:6px;margin-top:8px;display:flex}.tag-suggest-chip{border-radius:var(--radius-full);background:var(--color-surface-offset);color:var(--color-text-muted);border:1px solid var(--color-border);cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);align-items:center;gap:4px;padding:5px 12px;font-size:13px;display:inline-flex}.tag-suggest-chip:hover{background:var(--color-primary-highlight);color:var(--color-primary);border-color:var(--color-primary)}.tag-suggest-chip.used{opacity:.4;pointer-events:none}.upload-footer{background:var(--color-bg);border-top:1px solid var(--color-divider);margin-top:24px;padding:16px 0;position:sticky;bottom:0}.admin-gate{text-align:center;background:var(--color-surface);border-radius:var(--radius-lg);max-width:380px;box-shadow:var(--shadow-elevated);border:1px solid var(--color-border);margin:60px auto;padding:40px 24px}@media (width<=420px){.admin-gate{margin:40px 16px;padding:32px 20px}.admin-gate .form-input-wrap{flex-direction:column}.admin-gate .form-input-wrap .btn-primary{width:100%!important}}.admin-gate svg{width:48px;height:48px;color:var(--color-primary);margin-bottom:16px}.admin-gate h2{font-family:var(--font-display);margin-bottom:4px;font-size:24px;font-weight:500}.admin-gate p{color:var(--color-text-muted);margin-bottom:24px;font-size:14px}.admin-gate .form-input-wrap{gap:8px;display:flex}.form-input{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface-2);color:var(--color-text);font-family:var(--font-body);transition:border-color var(--transition-fast);flex:1;padding:12px;font-size:16px}.form-input:focus{border-color:var(--color-primary);outline:none}.admin-gate .error-text{color:var(--color-error);margin-top:10px;font-size:13px}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-6px)}80%{transform:translate(6px)}}.shake{animation:.4s shake}.admin-toolbar{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:16px;display:flex}.admin-toolbar .photo-count{flex:1}.admin-grid{columns:3 240px;column-gap:12px}.admin-card{break-inside:avoid;border-radius:var(--radius-md);background:var(--color-surface);box-shadow:var(--shadow-card);transition:border-color var(--transition-fast), opacity var(--transition-slow), transform var(--transition-slow), max-height var(--transition-slow), margin var(--transition-slow);border:2px solid #0000;margin-bottom:12px;position:relative;overflow:hidden}.admin-card.selected{border-color:var(--color-primary)}.admin-card.removing{opacity:0;max-height:0;margin:0;overflow:hidden;transform:scale(.9)}.admin-card img,.admin-card video{width:100%;display:block}.admin-card-overlay{gap:6px;display:flex;position:absolute;top:8px;right:8px}.admin-delete-btn{border-radius:var(--radius-full);background:var(--color-error);color:#fff;cursor:pointer;width:36px;height:36px;transition:opacity var(--transition-fast);border:none;justify-content:center;align-items:center;display:flex;box-shadow:0 2px 6px #0000004d}.admin-delete-btn:hover{opacity:.85}.admin-delete-btn svg{width:18px;height:18px}.admin-select-check{border-radius:var(--radius-sm);cursor:pointer;color:#fff;width:28px;height:28px;transition:background var(--transition-fast);background:#0000004d;border:2px solid #ffffffb3;justify-content:center;align-items:center;display:none;position:absolute;top:8px;left:8px}.admin-select-check svg{width:18px;height:18px}.bulk-mode .admin-select-check{display:flex}.admin-card.selected .admin-select-check{background:var(--color-primary);border-color:var(--color-primary)}.admin-card-caption{color:var(--color-text-muted);white-space:nowrap;text-overflow:ellipsis;padding:8px 10px;font-size:13px;overflow:hidden}.lightbox{z-index:1000;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#000000e0;flex-direction:column;justify-content:center;align-items:center;padding:16px;display:none;position:fixed;inset:0}.lightbox.open{animation:lbFadeIn .22s var(--ease-out-expo);display:flex}.lightbox-close{border-radius:var(--radius-full);cursor:pointer;color:#fff;width:44px;height:44px;transition:background var(--transition-fast);z-index:10;background:#ffffff1f;border:none;justify-content:center;align-items:center;display:flex;position:absolute;top:16px;right:16px}.lightbox-close:hover{background:#ffffff40}.lightbox-close svg{width:24px;height:24px}.lightbox-img-wrap{max-width:90vw;max-height:75vh;animation:lbZoom .22s var(--ease-out-expo);justify-content:center;align-items:center;display:flex}.lightbox-img-wrap img{border-radius:var(--radius-md);object-fit:contain;max-width:100%;max-height:75vh}.lightbox-info{text-align:center;color:#fff;max-width:600px;margin-top:16px}.lightbox-loader{border-radius:var(--radius-md);z-index:1;background:#0000004d;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.lightbox-loader .spinner{border:3px solid #fff3;border-top-color:#fff;border-radius:50%;width:36px;height:36px;animation:.7s linear infinite spin}.lightbox-counter{color:#ffffff8c;margin-bottom:6px;font-size:13px}.lightbox-caption{margin-bottom:8px;font-size:15px;line-height:1.5}.lightbox-tags{flex-wrap:wrap;justify-content:center;gap:6px;display:flex}.lightbox-tag{border-radius:var(--radius-full);color:#ffffffd9;background:#ffffff26;padding:3px 10px;font-size:12px}.lightbox-nav{border-radius:var(--radius-full);color:#fff;cursor:pointer;width:48px;height:48px;transition:background var(--transition-fast);background:#ffffff1f;border:none;justify-content:center;align-items:center;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.lightbox-nav:hover{background:#ffffff40}.lightbox-nav svg{width:24px;height:24px}.lightbox-prev{left:16px}.lightbox-next{right:16px}@keyframes lbFadeIn{0%{opacity:0}to{opacity:1}}@keyframes lbZoom{0%{opacity:0;transform:scale(.94)}to{opacity:1;transform:scale(1)}}
