.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem;background:linear-gradient(135deg,#667eea,#764ba2)}.auth-card{background:#fff;border-radius:1rem;padding:2rem;width:100%;max-width:400px;box-shadow:0 10px 40px #0003}.auth-title{font-size:1.75rem;font-weight:700;color:#1a1a2e;margin:0 0 .5rem;text-align:center}.auth-subtitle{color:#6b7280;text-align:center;margin:0 0 1.5rem}.auth-form{display:flex;flex-direction:column;gap:1rem}.auth-error{background:#fee2e2;color:#dc2626;padding:.75rem;border-radius:.5rem;font-size:.875rem}.form-group input{padding:.75rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:1rem;transition:border-color .15s,box-shadow .15s}.btn{padding:.75rem 1.5rem;border-radius:.5rem;font-size:1rem;font-weight:500;cursor:pointer;transition:all .15s;border:none}.auth-links{margin-top:1.5rem;display:flex;flex-direction:column;gap:.5rem;text-align:center}.link-btn{background:none;border:none;color:#667eea;cursor:pointer;font-size:.875rem;padding:.25rem}.link-btn:hover{text-decoration:underline}.layout{min-height:100vh;display:flex;flex-direction:column;background:#f8f9fa}.header{background:#fff;border-bottom:1px solid #e5e7eb;position:sticky;top:0;z-index:100}.header-content{max-width:1200px;margin:0 auto;padding:.75rem 1rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.header-logo{font-size:1.25rem;font-weight:700;color:#1a1a2e;text-decoration:none;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-nav{display:flex;gap:.5rem}.nav-link{padding:.5rem 1rem;border-radius:.5rem;text-decoration:none;color:#6b7280;font-weight:500;transition:all .15s}.nav-link:hover{background:#f3f4f6;color:#374151}.nav-link.active{background:#eef2ff;color:#667eea}.header-actions{display:flex;align-items:center;gap:.75rem}.upload-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.5rem 1rem;border-radius:.5rem;font-weight:500;cursor:pointer;transition:transform .15s,box-shadow .15s}.upload-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}.user-menu{position:relative}.user-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;overflow:hidden}.user-avatar img{width:100%;height:100%;object-fit:cover}.user-avatar span{color:#fff;font-size:.75rem;font-weight:600}.menu-dropdown{position:absolute;top:100%;right:0;margin-top:.5rem;background:#fff;border-radius:.75rem;box-shadow:0 10px 40px #00000026;min-width:200px;overflow:hidden;animation:fadeIn .15s ease-out}.menu-user{padding:1rem;display:flex;flex-direction:column;gap:.25rem}.menu-user strong{color:#1a1a2e}.menu-user span{font-size:.75rem;color:#6b7280}.menu-divider{height:1px;background:#e5e7eb}.menu-item{display:block;width:100%;padding:.75rem 1rem;background:none;border:none;text-align:left;cursor:pointer;color:#374151;font-size:.875rem;transition:background .15s}.menu-item:hover{background:#f3f4f6}.menu-install{color:#667eea}.menu-install:hover{background:#eef2ff}.menu-logout{color:#dc2626}.menu-logout:hover{background:#fee2e2}.main-content{flex:1;padding:1rem 0}.invite-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.invite-content{background:#fff;border-radius:1rem;padding:2rem;text-align:center;max-width:320px}.invite-content h3{margin:0 0 .5rem;color:#1a1a2e}.invite-content p{margin:0;color:#6b7280;font-size:.875rem}.invite-code{font-size:2rem;font-weight:700;letter-spacing:.1em;color:#667eea;background:#f5f7ff;padding:1rem;border-radius:.5rem;margin:1rem 0}.invite-note{font-size:.75rem;color:#9ca3af;margin-bottom:1rem!important}@media (max-width: 600px){.header-content{flex-wrap:wrap}.header-logo{font-size:1rem}.header-nav{order:3;width:100%;justify-content:center;padding-top:.5rem;border-top:1px solid #e5e7eb;margin-top:.5rem}.nav-link{padding:.4rem 1rem;font-size:.875rem}.upload-btn{padding:.5rem;font-size:.875rem}}.reactions{position:relative}.reactions-list{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.reaction-wrapper{position:relative}.reaction-badge{display:flex;align-items:center;gap:.25rem;padding:.25rem .5rem;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:1rem;cursor:pointer;transition:all .15s}.reaction-badge:hover{background:#e5e7eb}.reaction-badge.reacted{background:#eef2ff;border-color:#667eea}.reaction-emoji{font-size:1rem}.reaction-count{font-size:.75rem;color:#6b7280}.reaction-add{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#f3f4f6;border:1px dashed #d1d5db;border-radius:50%;cursor:pointer;font-size:1rem;color:#6b7280;transition:all .15s}.reaction-add:hover{background:#e5e7eb;border-color:#9ca3af}.emoji-picker-container{position:absolute;top:100%;left:0;z-index:1000;margin-top:.5rem;box-shadow:0 10px 40px #00000040;border-radius:.75rem;background:#fff}@media (max-width: 480px){.emoji-picker-container{position:fixed;left:50%;top:50%;transform:translate(-50%,-50%);margin-top:0}}.reaction-tooltip{position:absolute;bottom:100%;left:50%;transform:translate(-50%);margin-bottom:.5rem;background:#fff;border-radius:.75rem;box-shadow:0 4px 20px #00000026;padding:.75rem;min-width:140px;z-index:100;animation:tooltipFadeIn .15s ease-out}.reaction-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:#fff}@keyframes tooltipFadeIn{0%{opacity:0;transform:translate(-50%) translateY(4px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.reaction-tooltip-header{display:flex;align-items:center;gap:.5rem;padding-bottom:.5rem;border-bottom:1px solid #e5e7eb;margin-bottom:.5rem}.reaction-tooltip-emoji{font-size:1.25rem}.reaction-tooltip-count{font-size:.875rem;font-weight:600;color:#374151}.reaction-tooltip-users{list-style:none;margin:0;padding:0;max-height:150px;overflow-y:auto}.reaction-tooltip-users li{padding:.25rem 0;font-size:.8125rem;color:#4b5563;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.reaction-bottom-sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:1000;display:flex;align-items:flex-end;animation:fadeIn .2s ease-out}.reaction-bottom-sheet{width:100%;background:#fff;border-radius:1.5rem 1.5rem 0 0;padding:.75rem 1.5rem 1.5rem;padding-bottom:max(1.5rem,env(safe-area-inset-bottom));animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.reaction-bottom-sheet-handle{width:36px;height:4px;background:#d1d5db;border-radius:2px;margin:0 auto 1rem}.reaction-bottom-sheet-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.reaction-bottom-sheet-emoji{font-size:2rem}.reaction-bottom-sheet-title{font-size:1.125rem;font-weight:600;color:#1a1a2e}.reaction-bottom-sheet-users{list-style:none;margin:0;padding:0;max-height:200px;overflow-y:auto;margin-bottom:1rem}.reaction-bottom-sheet-users li{padding:.75rem 0;font-size:1rem;color:#374151;border-bottom:1px solid #f3f4f6}.reaction-bottom-sheet-users li:last-child{border-bottom:none}.reaction-bottom-sheet-btn{width:100%;padding:1rem;border:none;border-radius:.75rem;font-size:1rem;font-weight:500;cursor:pointer;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;transition:transform .15s,box-shadow .15s}.reaction-bottom-sheet-btn:active{transform:scale(.98)}.reaction-bottom-sheet-btn.reacted{background:#f3f4f6;color:#6b7280}.comments{margin-top:.75rem}.comments-loading{color:#6b7280;font-size:.875rem;padding:.5rem 0}.comments-show-more{background:none;border:none;color:#667eea;font-size:.875rem;cursor:pointer;padding:.25rem 0;margin-bottom:.5rem;display:block}.comments-show-more:hover{color:#5a6fd6;text-decoration:underline}.comments-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:.75rem}.comment{display:flex;gap:.5rem}.comment-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}.comment-avatar img{width:100%;height:100%;object-fit:cover}.comment-avatar span{color:#fff;font-size:.625rem;font-weight:600}.comment-body{flex:1;background:#f3f4f6;border-radius:.75rem;padding:.5rem .75rem}.comment-header{display:flex;align-items:baseline;gap:.5rem}.comment-name{font-size:.875rem;font-weight:600;color:#1a1a2e}.comment-time{font-size:.625rem;color:#9ca3af}.comment-content{margin:.25rem 0 0;font-size:.875rem;color:#374151;line-height:1.4}.comment-actions{display:flex;gap:.5rem;margin-top:.25rem}.comment-actions button{background:none;border:none;color:#6b7280;font-size:.75rem;cursor:pointer;padding:0}.comment-actions button:hover{color:#374151}.comment-edit{margin-top:.25rem}.comment-edit input{width:100%;padding:.375rem .5rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem}.comment-edit-actions{display:flex;gap:.5rem;margin-top:.375rem}.comment-edit-actions button{background:none;border:none;font-size:.75rem;cursor:pointer;color:#667eea}.comment-form{display:flex;gap:.5rem}.comment-form input{flex:1;padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:1rem;font-size:.875rem}.comment-form input:focus{outline:none;border-color:#667eea}.comment-form button{background:#667eea;color:#fff;border:none;padding:.5rem 1rem;border-radius:1rem;font-size:.875rem;cursor:pointer;transition:background .15s}.comment-form button:hover:not(:disabled){background:#5a6fd6}.comment-form button:disabled{opacity:.5;cursor:not-allowed}.photo-viewer{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000f2;z-index:1000;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease-out}.photo-viewer-content{position:relative;width:100%;height:100%;display:flex;flex-direction:column;overflow:hidden}.photo-viewer-close{position:absolute;top:1rem;right:1rem;background:#ffffff1a;border:none;color:#fff;width:40px;height:40px;border-radius:50%;font-size:1.5rem;cursor:pointer;z-index:10;transition:background .2s}.photo-viewer-close:hover{background:#fff3}.photo-viewer-image{flex:1;min-height:0;display:flex;align-items:center;justify-content:center;padding:3.5rem 1rem 1rem;overflow:hidden;touch-action:pan-y pinch-zoom;user-select:none;-webkit-user-select:none}.photo-viewer-image img{max-width:100%;max-height:100%;object-fit:contain;pointer-events:none}.photo-viewer-nav{position:absolute;top:50%;transform:translateY(-50%);background:#ffffff1a;border:none;color:#fff;width:50px;height:50px;border-radius:50%;font-size:2rem;cursor:pointer;transition:background .2s}.photo-viewer-nav:hover{background:#fff3}.photo-viewer-prev{left:1rem}.photo-viewer-next{right:1rem}.photo-viewer-footer{flex-shrink:0;display:flex;justify-content:space-between;align-items:center;padding:1rem;padding-bottom:max(1rem,env(safe-area-inset-bottom));background:#00000080}.photo-viewer-info{display:flex;flex-direction:column;gap:.25rem}.photo-viewer-name{color:#fff;font-size:.875rem}.photo-viewer-count{color:#ffffffb3;font-size:.75rem}.photo-viewer-download{background:#667eea;border:none;color:#fff;padding:.5rem 1rem;border-radius:.5rem;cursor:pointer;font-size:.875rem;transition:background .2s}.photo-viewer-download:hover{background:#5a6fd6}@media (max-width: 600px){.photo-viewer-image{padding:3rem .5rem .5rem}.photo-viewer-nav{width:40px;height:40px;font-size:1.5rem}.photo-viewer-prev{left:.5rem}.photo-viewer-next{right:.5rem}}.photo-card{background:#fff;border-radius:1rem;box-shadow:0 2px 8px #00000014}.photo-card-header{display:flex;align-items:center;gap:.75rem;padding:1rem}.photo-card-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;overflow:hidden}.photo-card-avatar img{width:100%;height:100%;object-fit:cover}.photo-card-avatar span{color:#fff;font-size:.875rem;font-weight:600}.photo-card-info{display:flex;flex-direction:column}.photo-card-name{font-weight:600;color:#1a1a2e}.photo-card-time{font-size:.75rem;color:#6b7280}.photo-card-grid{display:grid;gap:2px;overflow:hidden}.photo-count-1{grid-template-columns:1fr}.photo-count-2{grid-template-columns:1fr 1fr}.photo-count-3{grid-template-columns:2fr 1fr;grid-template-rows:1fr 1fr}.photo-count-3 .photo-card-image:first-child{grid-row:span 2}.photo-count-4{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}.photo-card-image{position:relative;aspect-ratio:1;overflow:hidden;cursor:pointer}.photo-count-1 .photo-card-image{aspect-ratio:4/3}.photo-card-image img{width:100%;height:100%;object-fit:cover;transition:transform .2s}.photo-card-image:hover img{transform:scale(1.05)}.photo-card-more{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.5rem;font-weight:600}.photo-card-caption{padding:.75rem 1rem;margin:0;color:#374151;line-height:1.5}.photo-card-actions{padding:0 1rem 1rem}.photo-interactions{border-top:1px solid #e5e7eb;padding-top:.75rem;margin-top:.75rem}.photo-interactions:first-child{border-top:none;margin-top:0}.albums-page{padding:1rem;max-width:1200px;margin:0 auto}.albums-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.albums-header h1{margin:0;font-size:1.5rem;color:#1a1a2e}.albums-loading,.albums-error,.albums-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center;color:#6b7280}.albums-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.album-card{background:#fff;border-radius:1rem;box-shadow:0 2px 8px #00000014;overflow:hidden;transition:transform .2s,box-shadow .2s}.album-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000001f}.album-card.in-feed{max-width:100%}.album-card-header{display:flex;align-items:center;gap:.75rem;padding:1rem}.album-card-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;overflow:hidden}.album-card-avatar img{width:100%;height:100%;object-fit:cover}.album-card-avatar span{color:#fff;font-size:.875rem;font-weight:600}.album-card-info{display:flex;flex-wrap:wrap;gap:.25rem;align-items:baseline}.album-card-name{font-weight:600;color:#1a1a2e}.album-card-action{color:#6b7280;font-size:.875rem}.album-card-time{font-size:.75rem;color:#9ca3af}.album-card-link{text-decoration:none;color:inherit;display:block}.album-card-cover{aspect-ratio:16/9;background:#f3f4f6;overflow:hidden}.album-card-cover img{width:100%;height:100%;object-fit:cover}.album-card-preview-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px;height:100%}.album-card-preview-grid img{width:100%;height:100%;object-fit:cover}.album-card-empty{display:flex;align-items:center;justify-content:center;height:100%;color:#9ca3af}.album-card-details{padding:1rem}.album-card-title{margin:0;font-size:1rem;font-weight:600;color:#1a1a2e}.album-card-description{margin:.25rem 0 0;font-size:.875rem;color:#6b7280;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.album-card-count{font-size:.75rem;color:#9ca3af;margin-top:.5rem;display:block}.album-card-social{padding:.5rem 1rem 1rem;border-top:1px solid #e5e7eb}.create-album-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.create-album-content{background:#fff;border-radius:1rem;width:100%;max-width:400px}.create-album-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid #e5e7eb}.create-album-header h2{margin:0;font-size:1.25rem}.create-album-close{background:none;border:none;font-size:1.5rem;color:#6b7280;cursor:pointer}.create-album-content form{padding:1.5rem}.create-album-content textarea{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:.5rem;font-family:inherit;font-size:.875rem;resize:none}.create-album-actions{display:flex;gap:.75rem;margin-top:1.5rem;justify-content:flex-end}.create-album-error{margin-top:1rem;padding:.75rem;background:#fee2e2;color:#dc2626;border-radius:.5rem;font-size:.875rem}.album-detail{padding:1rem;max-width:1200px;margin:0 auto}.album-detail-loading,.album-detail-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center;gap:1rem}.album-detail-header{margin-bottom:1.5rem}.back-button{background:none;border:none;color:#667eea;cursor:pointer;font-size:1rem;padding:0;margin-bottom:1rem}.album-detail-info h1{margin:0 0 .5rem;font-size:1.75rem;color:#1a1a2e}.album-detail-info p{margin:0 0 .5rem;color:#6b7280}.album-detail-meta{font-size:.875rem;color:#9ca3af}.album-detail-actions{display:flex;gap:.75rem;margin-top:1rem}.btn-danger{background:#fee2e2;color:#dc2626}.btn-danger:hover{background:#fecaca}.album-edit-form{display:flex;flex-direction:column;gap:1rem}.album-edit-form input,.album-edit-form textarea{padding:.75rem;border:1px solid #d1d5db;border-radius:.5rem;font-family:inherit;font-size:1rem}.album-edit-actions{display:flex;gap:.75rem}.album-photos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.5rem}.album-photo{position:relative;aspect-ratio:1;border-radius:.5rem;overflow:hidden;cursor:pointer}.album-photo img{width:100%;height:100%;object-fit:cover;transition:transform .2s}.album-photo:hover img{transform:scale(1.05)}.album-photo-remove{position:absolute;top:.5rem;right:.5rem;width:28px;height:28px;border-radius:50%;background:#0009;border:none;color:#fff;cursor:pointer;font-size:1rem;opacity:0;transition:opacity .2s}.album-photo:hover .album-photo-remove{opacity:1}.album-empty{text-align:center;padding:3rem;color:#6b7280}.add-photos-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.add-photos-content{background:#fff;border-radius:1rem;width:100%;max-width:700px;max-height:80vh;display:flex;flex-direction:column}.add-photos-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid #e5e7eb}.add-photos-header h2{margin:0;font-size:1.25rem}.add-photos-close{background:none;border:none;font-size:1.5rem;color:#6b7280;cursor:pointer}.add-photos-loading,.add-photos-empty{padding:3rem;text-align:center;color:#6b7280}.add-photos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.5rem;padding:1rem;overflow-y:auto;flex:1}.add-photos-item{position:relative;aspect-ratio:1;border-radius:.5rem;overflow:hidden;cursor:pointer;border:2px solid transparent}.add-photos-item img{width:100%;height:100%;object-fit:cover}.add-photos-item.selected{border-color:#667eea}.add-photos-checkbox{position:absolute;top:.25rem;right:.25rem;width:24px;height:24px;border-radius:50%;background:#fff;border:2px solid #d1d5db;display:flex;align-items:center;justify-content:center;font-size:.875rem;color:#667eea}.add-photos-item.selected .add-photos-checkbox{background:#667eea;border-color:#667eea;color:#fff}.add-photos-actions{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-top:1px solid #e5e7eb}.add-photos-count{font-size:.875rem;color:#6b7280}.add-photos-buttons{display:flex;gap:.75rem}.add-photos-tabs{display:flex;border-bottom:1px solid #e5e7eb}.add-photos-tab{flex:1;padding:.75rem 1rem;background:none;border:none;font-size:.875rem;font-weight:500;color:#6b7280;cursor:pointer;transition:all .15s;border-bottom:2px solid transparent;margin-bottom:-1px}.add-photos-tab:hover{color:#374151;background:#f9fafb}.add-photos-tab.active{color:#667eea;border-bottom-color:#667eea}.add-photos-dropzone{margin:1rem;border:2px dashed #d1d5db;border-radius:.75rem;padding:2rem;text-align:center;cursor:pointer;transition:all .2s}.add-photos-dropzone:hover,.add-photos-dropzone.active{border-color:#667eea;background:#f5f7ff}.add-photos-dropzone-content{display:flex;flex-direction:column;align-items:center;gap:.5rem}.add-photos-dropzone-icon{width:48px;height:48px;border-radius:50%;background:#eef2ff;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#667eea}.add-photos-dropzone p{margin:0;color:#374151;font-weight:500}.add-photos-dropzone span{font-size:.75rem;color:#9ca3af}.add-photos-remove{position:absolute;top:.25rem;right:.25rem;width:24px;height:24px;border-radius:50%;background:#0009;border:none;color:#fff;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center}.feed{display:flex;flex-direction:column;gap:1.5rem;padding:1rem;max-width:600px;margin:0 auto}.feed-item{animation:fadeIn .3s ease-out}.feed-loading,.feed-error,.feed-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center;color:#6b7280}.feed-loading-more{display:flex;justify-content:center;padding:1rem}.spinner{width:32px;height:32px;border:3px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite}.upload-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.upload-content{background:#fff;border-radius:1rem;width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.upload-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid #e5e7eb}.upload-header h2{margin:0;font-size:1.25rem;color:#1a1a2e}.upload-close{background:none;border:none;font-size:1.5rem;color:#6b7280;cursor:pointer;padding:0;line-height:1}.upload-close:hover{color:#374151}.upload-content form{padding:1.5rem}.upload-dropzone{border:2px dashed #d1d5db;border-radius:.75rem;padding:2rem;text-align:center;cursor:pointer;transition:all .2s}.upload-dropzone:hover,.upload-dropzone.active{border-color:#667eea;background:#f5f7ff}.upload-dropzone-content{display:flex;flex-direction:column;align-items:center;gap:.5rem}.upload-icon{width:48px;height:48px;border-radius:50%;background:#eef2ff;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#667eea}.upload-dropzone p{margin:0;color:#374151;font-weight:500}.upload-dropzone span{font-size:.75rem;color:#9ca3af}.upload-previews{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem;margin-top:1rem}.upload-preview{position:relative;aspect-ratio:1;border-radius:.5rem;overflow:hidden}.upload-preview img{width:100%;height:100%;object-fit:cover}.upload-preview-remove{position:absolute;top:.25rem;right:.25rem;width:24px;height:24px;border-radius:50%;background:#0009;border:none;color:#fff;cursor:pointer;font-size:1rem;line-height:1}.upload-caption{margin-top:1rem}.upload-caption textarea{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:.5rem;font-family:inherit;font-size:.875rem;resize:none}.upload-caption textarea:focus{outline:none;border-color:#667eea}.upload-actions{display:flex;gap:.75rem;margin-top:1.5rem;justify-content:flex-end}.btn-secondary:hover{background:#e5e7eb}.upload-error{margin-top:1rem;padding:.75rem;background:#fee2e2;color:#dc2626;border-radius:.5rem;font-size:.875rem}.install-prompt{background:linear-gradient(135deg,#667eea,#764ba2);padding:.75rem 1rem;padding-top:max(.75rem,env(safe-area-inset-top));animation:slideDown .3s ease-out}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.install-prompt-content{max-width:1200px;margin:0 auto;display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.install-prompt-icon{width:36px;height:36px;background:#fff3;border-radius:.5rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.install-prompt-icon svg{width:20px;height:20px;color:#fff}.install-prompt-text{flex:1;min-width:150px}.install-prompt-text strong{display:block;color:#fff;font-size:.9375rem}.install-prompt-text p{margin:0;color:#ffffffd9;font-size:.8125rem}.install-prompt-actions{display:flex;gap:.5rem}.install-prompt-btn{padding:.5rem 1rem;border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;border:none;transition:opacity .15s}.install-prompt-btn:active{opacity:.8}.install-prompt-btn.install{background:#fff;color:#667eea}.install-prompt-btn.dismiss{background:#fff3;color:#fff}.update-prompt{position:fixed;bottom:1rem;left:1rem;right:1rem;z-index:1000;background:#1a1a2e;border-radius:1rem;padding:1rem;box-shadow:0 10px 40px #0000004d;animation:slideUp .3s ease-out;max-width:400px;margin:0 auto}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.update-prompt-content{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.update-prompt-icon{width:40px;height:40px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:.5rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.update-prompt-icon svg{width:22px;height:22px;color:#fff}.update-prompt-text{flex:1;min-width:120px}.update-prompt-text strong{display:block;color:#fff;font-size:.9375rem}.update-prompt-text p{margin:0;color:#ffffffb3;font-size:.8125rem}.update-prompt-actions{display:flex;gap:.5rem}.update-prompt-btn{padding:.5rem 1rem;border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;border:none;transition:opacity .15s}.update-prompt-btn:active{opacity:.8}.update-prompt-btn.update{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.update-prompt-btn.dismiss{background:#ffffff1a;color:#ffffffb3}.offline-indicator{position:fixed;bottom:1rem;left:50%;transform:translate(-50%);z-index:999;background:#ef4444;color:#fff;padding:.5rem 1rem;border-radius:2rem;display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:500;box-shadow:0 4px 12px #ef44444d;animation:fadeInUp .3s ease-out}@keyframes fadeInUp{0%{transform:translate(-50%) translateY(20px);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.offline-indicator svg{width:18px;height:18px}@media (max-width: 600px){.install-prompt-content{flex-wrap:nowrap}.install-prompt-text p{display:none}.install-prompt-actions{flex-shrink:0}.update-prompt{left:.5rem;right:.5rem;bottom:.5rem;bottom:max(.5rem,env(safe-area-inset-bottom))}.offline-indicator{bottom:max(1rem,env(safe-area-inset-bottom))}}*{box-sizing:border-box}html{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;padding:0;background:#f8f9fa}.app-loading{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem}.spinner{width:40px;height:40px;border:3px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.btn{padding:.75rem 1.5rem;border-radius:.5rem;font-size:1rem;font-weight:500;cursor:pointer;transition:all .15s;border:none;font-family:inherit}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:#f3f4f6;color:#374151}.btn-secondary:hover:not(:disabled){background:#e5e7eb}.form-group{display:flex;flex-direction:column;gap:.375rem}.form-group label{font-size:.875rem;font-weight:500;color:#374151}.form-group input{padding:.75rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:1rem;transition:border-color .15s,box-shadow .15s;font-family:inherit}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a1a1a1}
