@import"https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,600;1,400&family=DM+Sans:wght@400;500&display=swap";:root{--color-bg: #faf9f7;--color-bg-alt: #f0eeeb;--color-text: #1a1a1a;--color-text-muted: #6b6b6b;--color-accent: #2d2d2d;--color-border: #e5e3df;--color-overlay: rgba(0, 0, 0, .85);--font-display: "Cormorant Garamond", Georgia, serif;--font-body: "DM Sans", -apple-system, sans-serif;--space-xs: .5rem;--space-sm: 1rem;--space-md: 2rem;--space-lg: 4rem;--space-xl: 8rem;--transition-fast: .15s ease;--transition-smooth: .3s cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-body);background:var(--color-bg);color:var(--color-text);line-height:1.6;-webkit-font-smoothing:antialiased}img{max-width:100%;display:block}a{color:inherit;text-decoration:none}.app{min-height:100vh;display:flex;flex-direction:column}.header{position:sticky;top:0;z-index:100;background:var(--color-bg);border-bottom:1px solid var(--color-border)}.header-container{max-width:1600px;margin:0 auto;padding:var(--space-sm) var(--space-md);display:flex;justify-content:space-between;align-items:center}.logo{font-family:var(--font-display);font-size:1.75rem;font-weight:400;letter-spacing:.02em}.nav-desktop{display:flex;gap:var(--space-md)}.nav-link{font-size:.875rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase;padding:var(--space-xs) 0;position:relative;transition:color var(--transition-fast)}.nav-link:after{content:"";position:absolute;bottom:0;left:0;width:0;height:1px;background:var(--color-text);transition:width var(--transition-smooth)}.nav-link:hover:after,.nav-link.active:after{width:100%}.menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:var(--space-xs)}.nav-mobile{display:none;flex-direction:column;padding:var(--space-sm) var(--space-md);border-top:1px solid var(--color-border)}.nav-mobile .nav-link{padding:var(--space-sm) 0}@media(max-width:768px){.nav-desktop{display:none}.menu-toggle{display:block}.nav-mobile{display:flex}}.hero{text-align:center;padding:var(--space-sm) var(--space-sm);background:linear-gradient(180deg,var(--color-bg-alt) 0%,var(--color-bg) 100%)}.hero-title{font-family:var(--font-display);font-size:clamp(2.5rem,8vw,5rem);font-weight:400;line-height:1.1;margin-bottom:var(--space-sm);letter-spacing:-.02em}.hero-subtitle{font-size:1.125rem;color:var(--color-text-muted);font-style:italic}.gallery-section{padding:var(--space-sm) var(--space-md);max-width:1600px;margin:0 auto}.date-group{margin-bottom:var(--space-lg)}.date-group:last-child{margin-bottom:0}.date-separator{margin-bottom:var(--space-md);text-align:center;position:relative;display:flex;align-items:center;justify-content:center}.date-separator:before,.date-separator:after{content:"";flex:1;height:1px;background:var(--color-border)}.date-separator:before{margin-right:var(--space-md)}.date-separator:after{margin-left:var(--space-md)}.date-header{font-family:var(--font-display);font-size:1.5rem;font-weight:400;color:var(--color-text);letter-spacing:.02em;white-space:nowrap;padding:0 var(--space-sm)}.grid-size-control{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-md);padding:var(--space-sm) var(--space-md);background:#ffffff0d;border-radius:var(--border-radius);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);width:100%;justify-content:flex-end}.grid-size-control label{font-size:.9rem;color:var(--color-text-muted);white-space:nowrap}.grid-size-control input[type=range]{width:120px;height:4px;background:#6b6b6b66;border-radius:2px;outline:none;-webkit-appearance:none;appearance:none}.grid-size-control input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;background:var(--color-accent);border-radius:50%;cursor:pointer}.grid-size-control input[type=range]::-moz-range-thumb{width:16px;height:16px;background:var(--color-accent);border-radius:50%;cursor:pointer;border:none}.grid-size-control .column-count{font-size:.9rem;font-weight:500;min-width:2ch;text-align:center}.grid-size-control button{background:transparent;border:1px solid var(--color-border);color:var(--color-text);padding:var(--space-xs) var(--space-sm);border-radius:2px;font-size:.85rem;font-family:var(--font-body);font-weight:500;cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;gap:var(--space-xs);justify-content:center}.grid-size-control button:hover{border-color:var(--color-text);background:#00000005}@media(max-width:640px){.grid-size-control button{padding:var(--space-sm);font-size:.9rem}}.photo-grid{columns:var(--grid-columns, 3);column-gap:var(--space-sm)}@media(max-width:1024px){.photo-grid{columns:min(var(--grid-columns, 3),2)}}@media(max-width:640px){.photo-grid{columns:min(var(--grid-columns, 3),3);column-gap:var(--space-xs)}.grid-size-control{padding:var(--space-sm);flex-wrap:wrap;gap:var(--space-xs)}.grid-size-control button{flex:1 1 100%;min-width:100%}.grid-size-control label,.grid-size-control input[type=range],.grid-size-control .column-count{font-size:.85rem}.grid-size-control input[type=range]{flex:1;min-width:100px}}.photo-item{break-inside:avoid;-webkit-column-break-inside:avoid;page-break-inside:avoid;margin-bottom:var(--space-sm);cursor:pointer;display:inline-block;width:100%}.photo-wrapper{position:relative;overflow:hidden;background:var(--color-bg-alt);box-shadow:0 2px 8px #00000029,0 1px 3px #0000001f;transition:box-shadow var(--transition-smooth);display:block;width:100%}.photo-image{width:100%;height:auto;display:block;opacity:0;transition:opacity var(--transition-smooth),transform .6s ease}.photo-image.loaded{opacity:1}.photo-item:hover .photo-image{transform:scale(1.03)}.photo-item:hover .photo-wrapper{box-shadow:0 8px 16px #0000001f,0 2px 6px #00000014}.photo-overlay{position:absolute;inset:0;background:linear-gradient(transparent 60%,#000000b3);opacity:0;transition:opacity var(--transition-smooth);display:flex;align-items:flex-end;padding:var(--space-md)}.photo-item:hover .photo-overlay{opacity:1}.photo-title{color:#fff;font-family:var(--font-display);font-size:1.25rem;font-style:italic}.photo-item.selection-mode{cursor:pointer;-webkit-user-select:none;user-select:none}.photo-item.selected .photo-wrapper{box-shadow:0 0 0 2px var(--color-text),0 2px 8px #00000029}.photo-selection-checkbox{position:absolute;top:var(--space-xs);right:var(--space-xs);width:18px;height:18px;border:1.5px solid var(--color-text);border-radius:2px;background:#fffffff2;display:flex;align-items:center;justify-content:center;z-index:10;transition:all var(--transition-fast)}.photo-selection-checkbox svg{width:14px;height:14px}@media(max-width:640px){.photo-selection-checkbox{width:24px;height:24px;border-width:2px}.photo-selection-checkbox svg{width:18px;height:18px}}.photo-item.selected .photo-selection-checkbox{background:var(--color-text);border-color:var(--color-text)}.photo-item.selected .photo-selection-checkbox svg{color:#fff}.selection-toolbar{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-md);padding:var(--space-md);background:var(--color-bg-alt);border:1px solid var(--color-border);border-radius:2px;width:100%}.selection-toolbar-info{font-size:.9rem;color:var(--color-text);font-weight:500;font-family:var(--font-body)}.selection-toolbar-controls{display:flex;align-items:center;gap:var(--space-sm);margin-left:auto}.selection-toolbar select{background:#fff;border:1px solid var(--color-border);color:var(--color-text);padding:var(--space-xs) var(--space-sm);border-radius:2px;font-size:.85rem;font-family:var(--font-body);min-width:150px;cursor:pointer}.selection-toolbar select:hover{border-color:var(--color-text)}.selection-toolbar button{padding:var(--space-xs) var(--space-md);border-radius:2px;font-size:.85rem;font-weight:500;font-family:var(--font-body);transition:all var(--transition-fast);cursor:pointer}.selection-toolbar .btn-primary{background:var(--color-text);color:var(--color-bg);border:1px solid var(--color-text)}.selection-toolbar .btn-primary:hover:not(:disabled){background:var(--color-text-muted);border-color:var(--color-text-muted)}.selection-toolbar .btn-primary:disabled{opacity:.4;cursor:not-allowed}.selection-toolbar .btn-secondary{background:transparent;color:var(--color-text);border:1px solid var(--color-border)}.selection-toolbar .btn-secondary:hover{border-color:var(--color-text)}.selection-toolbar .btn-danger{background:transparent;color:#c23030;border:1px solid #c23030}.selection-toolbar .btn-danger:hover:not(:disabled){background:#c23030;color:#fff}.selection-toolbar .btn-danger:disabled{opacity:.4;cursor:not-allowed}@media(max-width:640px){.selection-toolbar{flex-direction:column;align-items:stretch;gap:var(--space-sm);padding:var(--space-sm)}.selection-toolbar-info{text-align:center;font-size:.95rem}.selection-toolbar-controls{margin-left:0;flex-direction:column;align-items:stretch;gap:var(--space-xs)}.selection-toolbar select{width:100%;min-width:auto;padding:var(--space-sm);font-size:.9rem}.selection-toolbar button{width:100%;padding:var(--space-sm);font-size:.9rem}}.lightbox{position:fixed;inset:0;z-index:1000;background:var(--color-overlay);display:flex;align-items:center;justify-content:center;padding:var(--space-md)}.lightbox-close{position:absolute;top:var(--space-md);right:var(--space-md);background:none;border:none;color:#fff;cursor:pointer;padding:var(--space-xs);opacity:.7;transition:opacity var(--transition-fast)}.lightbox-close:hover{opacity:1}.lightbox-nav{background:none;border:none;color:#fff;cursor:pointer;padding:var(--space-sm);opacity:.7;transition:opacity var(--transition-fast)}.lightbox-nav:hover{opacity:1}.lightbox-content{max-width:90vw;max-height:85vh;display:flex;flex-direction:column;align-items:center}.lightbox-image{max-width:100%;max-height:70vh;object-fit:contain}.lightbox-info{text-align:center;color:#fff}.lightbox-title{font-family:var(--font-display);font-size:1.5rem;font-weight:400;margin-bottom:var(--space-xs)}.lightbox-description{color:#fffc;margin-bottom:var(--space-sm)}.lightbox-sidebar-toggle{position:absolute;top:var(--space-md);right:var(--space-lg);padding:var(--space-xs);background:none;border:none;color:#fff;cursor:pointer;opacity:.7;transition:opacity var(--transition-fast);z-index:1001}.lightbox-sidebar-toggle:hover{opacity:1}.lightbox-sidebar{position:fixed;top:0;right:0;width:320px;height:100vh;background:#1a1a1afa;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-left:1px solid rgba(255,255,255,.1);z-index:1002;display:flex;flex-direction:column;box-shadow:-4px 0 20px #00000080}.lightbox-sidebar-header{padding:var(--space-md);border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center}.lightbox-sidebar-header h3{color:#fff;font-family:var(--font-display);font-size:1.25rem;font-weight:400;margin:0}.lightbox-sidebar-close{background:transparent;border:none;color:#fff9;cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center;transition:color var(--transition-fast)}.lightbox-sidebar-close:hover{color:#fff}.lightbox-sidebar-content{flex:1;overflow-y:auto;padding:var(--space-md)}.lightbox-sidebar-section{margin-bottom:var(--space-lg)}.lightbox-sidebar-section label{display:flex;align-items:center;gap:var(--space-xs);color:#fffc;font-size:.875rem;font-weight:500;margin-bottom:var(--space-xs);text-transform:uppercase;letter-spacing:.05em}.lightbox-sidebar-select{width:100%;padding:.6rem .8rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.15);border-radius:4px;color:#fff;font-size:.875rem;cursor:pointer;transition:all var(--transition-fast)}.lightbox-sidebar-select:hover:not(:disabled){background:#ffffff14;border-color:#ffffff40}.lightbox-sidebar-select:disabled{opacity:.5;cursor:not-allowed}.lightbox-sidebar-select option{background:var(--color-bg);color:var(--color-text)}.lightbox-sidebar-updating{display:block;margin-top:var(--space-xs);font-size:.75rem;color:#ffffff80;font-style:italic}.lightbox-sidebar-info{color:#fff9;font-size:.875rem;margin:0;padding:.6rem .8rem;background:#ffffff08;border-radius:4px;border:1px solid rgba(255,255,255,.08)}@media(max-width:768px){.lightbox-sidebar{width:280px}}.lightbox-exif{display:flex;gap:var(--space-md);justify-content:center;flex-wrap:wrap;font-size:.875rem;color:#fff9}.exif-item{display:flex;align-items:center;gap:var(--space-xs)}.lightbox-counter{position:absolute;bottom:var(--space-xs);left:50%;transform:translate(-50%);color:#fff9;font-size:.875rem;display:flex;align-items:center;gap:var(--space-md);min-width:200px;justify-content:center}.lightbox-counter-text{white-space:nowrap;min-width:60px;text-align:center}.lightbox-counter .lightbox-nav{visibility:visible;flex-shrink:0}.lightbox-counter .lightbox-nav:disabled{visibility:hidden;pointer-events:none}.page-header{text-align:center;padding:var(--space-md) var(--space-sm)}.page-header h1{font-family:var(--font-display);font-size:clamp(2rem,5vw,3.5rem);font-weight:400;margin-bottom:var(--space-xs);text-transform:capitalize}.page-header p{color:var(--color-text-muted)}.back-link{display:inline-flex;align-items:center;gap:var(--space-xs);font-size:.875rem;color:var(--color-text-muted);margin-bottom:var(--space-md);transition:color var(--transition-fast)}.back-link:hover{color:var(--color-text)}.albums-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:var(--space-md);padding:0 var(--space-md) var(--space-lg);max-width:1600px;margin:0 auto}@media(max-width:640px){.albums-grid{grid-template-columns:1fr;padding:0 var(--space-sm) var(--space-lg)}}.album-card{display:block;position:relative;overflow:hidden;aspect-ratio:4/3;background:var(--color-bg-alt)}.album-cover{position:absolute;inset:0}.album-cover img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}.album-card:hover .album-cover img{transform:scale(1.05)}.album-overlay{position:absolute;inset:0;background:linear-gradient(transparent 40%,#000c)}.album-info{position:absolute;bottom:0;left:0;right:0;padding:var(--space-md);color:#fff}.album-name{font-family:var(--font-display);font-size:1.75rem;font-weight:400;margin-bottom:var(--space-xs)}.album-count{font-size:.875rem;opacity:.8}.page-about{padding:var(--space-lg) var(--space-md)}.about-container{max-width:1000px;margin:0 auto;display:grid;grid-template-columns:1fr 1.5fr;gap:var(--space-lg);align-items:start}@media(max-width:768px){.about-container{grid-template-columns:1fr}}.about-image img{width:100%;aspect-ratio:3/4;object-fit:cover;filter:grayscale(20%)}.about-content h1{font-family:var(--font-display);font-size:3rem;font-weight:400;margin-bottom:var(--space-md)}.about-intro{font-size:1.25rem;line-height:1.7;margin-bottom:var(--space-md)}.about-content p{margin-bottom:var(--space-sm);color:var(--color-text-muted)}.about-gear{margin-top:var(--space-lg);padding-top:var(--space-md);border-top:1px solid var(--color-border)}.about-gear h2{font-family:var(--font-display);font-size:1.5rem;font-weight:400;margin-bottom:var(--space-sm)}.about-gear ul{list-style:none;color:var(--color-text-muted)}.about-gear li{padding:var(--space-xs) 0}.social-links{display:flex;gap:var(--space-md);margin-top:var(--space-lg)}.social-link{color:var(--color-text-muted);transition:color var(--transition-fast)}.social-link:hover{color:var(--color-text)}.loading,.error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:var(--space-sm);color:var(--color-text-muted)}.loading-spinner{width:40px;height:40px;border:2px solid var(--color-border);border-top-color:var(--color-text);border-radius:50%;animation:spin 1s linear infinite}.admin-container{width:100%;max-width:1200px;margin:0 auto;padding:var(--space-lg) var(--space-md);min-height:80vh}.admin-title{font-family:var(--font-display);font-size:clamp(2rem,5vw,3.5rem);font-weight:400;margin-bottom:var(--space-md);letter-spacing:-.02em}.admin-tabs{display:flex;gap:var(--space-md);margin-bottom:var(--space-lg);border-bottom:1px solid var(--color-border);width:100%}.admin-tab{padding:var(--space-sm) 0;background:transparent;border:none;color:var(--color-text);cursor:pointer;font-size:.875rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase;position:relative;font-family:var(--font-body);border-bottom:2px solid transparent;transition:color var(--transition-fast);display:flex;align-items:center;gap:8px}.admin-tab:hover{color:var(--color-accent)}.admin-tab.active{border-bottom-color:var(--color-text)}.admin-section-title{font-family:var(--font-display);font-size:1.75rem;font-weight:400;margin-bottom:var(--space-md)}.admin-card{background-color:var(--color-bg-alt);border:1px solid var(--color-border);border-radius:2px;padding:var(--space-md);width:100%;box-sizing:border-box}.admin-card-title{font-family:var(--font-display);font-size:1.25rem;font-weight:400;margin-bottom:var(--space-sm);word-wrap:break-word}.admin-form{margin-bottom:var(--space-lg);width:100%}.admin-form-grid{display:grid;grid-template-columns:1fr 1fr 150px auto;gap:var(--space-sm);margin-top:var(--space-sm);width:100%}@media(max-width:768px){.admin-form-grid{grid-template-columns:1fr}}.admin-input,.admin-select{padding:var(--space-sm);background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:2px;color:var(--color-text);font-family:var(--font-body);font-size:1rem;width:100%;box-sizing:border-box}.admin-input:focus,.admin-select:focus{outline:none;border-color:var(--color-accent)}.admin-button{padding:var(--space-sm) var(--space-md);background-color:var(--color-accent);color:var(--color-bg);border:none;border-radius:2px;cursor:pointer;font-size:.875rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase;font-family:var(--font-body);transition:opacity var(--transition-fast)}.admin-button:hover:not(:disabled){opacity:.9}.admin-button:disabled{background-color:var(--color-text-muted);cursor:not-allowed}.admin-button-danger{background-color:#fef2f2;color:#991b1b;border:1px solid #dc2626}.admin-button-danger:hover{background-color:#fee2e2}.admin-table{width:100%;margin-top:var(--space-sm);border-collapse:collapse;table-layout:fixed}.admin-table thead tr{border-bottom:1px solid var(--color-border)}.admin-table th{text-align:left;padding:var(--space-sm);font-size:.875rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-table th:last-child{text-align:right}.admin-table tbody tr{border-bottom:1px solid var(--color-border)}.admin-table td{padding:var(--space-sm);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-table td:last-child{text-align:right}.admin-badge{padding:4px 12px;border-radius:12px;font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em;display:inline-block}.admin-badge-admin{background-color:#2d2d2d;color:var(--color-bg)}.admin-badge-user{background-color:var(--color-bg);color:var(--color-text-muted);border:1px solid var(--color-border)}.admin-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md);width:100%}@media(max-width:768px){.admin-grid{grid-template-columns:1fr}}.admin-list{margin-top:var(--space-sm);width:100%}.admin-list-item{padding:var(--space-sm);background-color:transparent;border-radius:2px;margin-bottom:var(--space-xs);cursor:pointer;border:1px solid var(--color-border);transition:border-color var(--transition-fast);width:100%;box-sizing:border-box}.admin-list-item:hover{border-color:var(--color-accent)}.admin-list-item.active{background-color:var(--color-bg);border:2px solid var(--color-accent)}.admin-list-item-header{display:flex;justify-content:space-between;align-items:center}.admin-list-item-title{font-weight:500}.admin-list-item-subtitle{font-size:.75rem;color:var(--color-text-muted)}.admin-info-box{margin-bottom:var(--space-sm);padding:var(--space-sm);background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:2px;font-size:.875rem;color:var(--color-text-muted);font-style:italic}.admin-checkbox-label{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm);cursor:pointer;-webkit-user-select:none;user-select:none}.admin-checkbox-label input[type=checkbox]{cursor:pointer}.admin-scrollable{max-height:600px;overflow-y:auto}.admin-tab-content{width:100%;box-sizing:border-box}.admin-photo-item{display:flex;gap:var(--space-sm);align-items:center;width:100%}.admin-photo-thumbnail{width:60px;height:60px;object-fit:cover;border-radius:2px;flex-shrink:0;background-color:var(--color-bg)}.admin-photo-info{flex:1;min-width:0;overflow:hidden}.admin-photo-info .admin-list-item-title,.admin-photo-info .admin-list-item-subtitle{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-button-secondary{padding:var(--space-sm) var(--space-md);background-color:transparent;color:var(--color-text);border:1px solid var(--color-border);border-radius:2px;cursor:pointer;font-size:.875rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase;font-family:var(--font-body);transition:all var(--transition-fast);display:flex;align-items:center;gap:.5rem}.admin-button-secondary:hover:not(:disabled){background-color:var(--color-bg);border-color:var(--color-accent)}.admin-button-secondary:disabled{opacity:.5;cursor:not-allowed}.admin-header{margin-bottom:var(--space-lg)}.admin-header h1{font-family:var(--font-display);font-size:clamp(2rem,5vw,3.5rem);font-weight:400;letter-spacing:-.02em}.form-group{margin-bottom:var(--space-md)}.form-group label{display:block;font-size:.875rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase;margin-bottom:var(--space-xs);color:var(--color-text-muted)}.text-muted{color:var(--color-text-muted);font-size:.875rem}.upload-dropzone{border:2px dashed var(--color-border);border-radius:4px;padding:3rem 2rem;text-align:center;cursor:pointer;transition:all var(--transition-smooth);margin:var(--space-md) 0;background-color:var(--color-bg)}.upload-dropzone:hover{border-color:var(--color-accent);background-color:var(--color-bg-alt)}.upload-dropzone.dragging{border-color:var(--color-accent);background-color:var(--color-bg-alt);transform:scale(1.01)}.upload-dropzone svg{margin:0 auto var(--space-sm);opacity:.5}.upload-dropzone p{margin:var(--space-xs) 0}.new-album-form{background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:4px;padding:var(--space-md);margin-bottom:var(--space-md)}.new-album-form h3{font-family:var(--font-display);font-size:1.5rem;font-weight:400;margin-bottom:var(--space-md);display:flex;align-items:center;gap:var(--space-xs)}.file-preview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:var(--space-sm);margin:var(--space-md) 0}.file-preview-item{position:relative;aspect-ratio:1;border-radius:4px;overflow:hidden;background-color:var(--color-bg-alt);border:1px solid var(--color-border)}.file-preview-item img{width:100%;height:100%;object-fit:cover}.file-preview-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background-color:#00000080;opacity:0;transition:opacity var(--transition-fast)}.file-preview-item:hover .file-preview-overlay{opacity:1}.file-status{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-xs);color:#fff;text-align:center;padding:var(--space-sm)}.file-status.uploading{opacity:1}.file-status.success{background-color:#22c55ee6;opacity:1}.file-status.error{background-color:#ef4444e6;opacity:1}.file-remove-btn{position:absolute;top:var(--space-xs);right:var(--space-xs);background-color:#000000b3;color:#fff;border:none;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color var(--transition-fast)}.file-remove-btn:hover{background-color:#ef4444e6}.file-name{position:absolute;bottom:0;left:0;right:0;padding:var(--space-xs);background:linear-gradient(to top,rgba(0,0,0,.8),transparent);color:#fff;font-size:.75rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.error-message{font-size:.75rem;max-width:120px;word-wrap:break-word}.upload-actions{display:flex;gap:var(--space-sm);align-items:center;margin-top:var(--space-md);flex-wrap:wrap}.upload-success{display:flex;align-items:center;gap:var(--space-xs);color:#16a34a;font-weight:500;padding:var(--space-sm);background-color:#f0fdf4;border:1px solid #86efac;border-radius:4px}.upload-error{display:flex;align-items:center;gap:var(--space-xs);color:#dc2626;font-weight:500;padding:var(--space-sm);background-color:#fef2f2;border:1px solid #fca5a5;border-radius:4px}.spinner{width:24px;height:24px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}
