@import"https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;500;600;700;800&family=Cormorant+Garamond:wght@400;500;600;700&family=Inter:wght@300;400;500;600;700&display=swap";.toast-container{position:fixed;top:20px;right:20px;z-index:10000;pointer-events:none}.toast{background:white;border-radius:8px;box-shadow:0 4px 12px #00000026;margin-bottom:8px;padding:12px 16px;display:flex;align-items:center;justify-content:space-between;min-width:300px;max-width:400px;pointer-events:auto;border-left:4px solid #007bff;transition:all .3s ease-in-out;transform:translate(100%);opacity:0}.toast-show{transform:translate(0);opacity:1}.toast-hide{transform:translate(100%);opacity:0}.toast-content{display:flex;align-items:center;flex:1}.toast-icon{margin-right:10px;font-size:18px}.toast-message{flex:1;font-size:14px;line-height:1.4;color:#333;font-weight:500}.toast-close{background:none;border:none;font-size:18px;color:#666;cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;margin-left:12px;transition:background-color .2s ease}.toast-close:hover{background-color:#0000001a;color:#333}.toast-success{border-left-color:#28a745}.toast-error{border-left-color:#dc3545}.toast-warning{border-left-color:#ffc107}.toast-info{border-left-color:#17a2b8}@media (prefers-color-scheme: dark){.toast{background:#2d3748;box-shadow:0 4px 12px #0000004d}.toast-message{color:#e2e8f0}.toast-close{color:#a0aec0}.toast-close:hover{background-color:#ffffff1a;color:#e2e8f0}}@media (max-width: 768px){.toast-container{top:10px;right:10px;left:10px}.toast{min-width:auto;max-width:none;width:100%}}@keyframes toast-slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes toast-slide-out{0%{transform:translate(0);opacity:1}to{transform:translate(100%);opacity:0}}.qr-code-container{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:1.5rem;background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;max-width:100%}.qr-display{position:relative;display:flex;justify-content:center;align-items:center}.qr-image{border-radius:8px;box-shadow:0 2px 8px #00000026;transition:opacity .3s ease}.qr-image.loading{opacity:.7}.qr-image.loaded{opacity:1}.qr-fallback{display:flex;flex-direction:column;align-items:center;gap:.5rem}.qr-canvas{border-radius:8px;box-shadow:0 2px 8px #00000026}.qr-fallback-notice{color:#666;font-size:.75rem;text-align:center}.qr-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;background:#f8f9fa;border-radius:8px;border:2px dashed #dee2e6;gap:.5rem;color:#666}.qr-spinner{width:24px;height:24px;border:2px solid #e9ecef;border-top:2px solid #007bff;border-radius:50%;animation:qr-spin 1s linear infinite}@keyframes qr-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.qr-actions{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:center}.qr-actions .btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:1px solid #dee2e6;border-radius:6px;background:#fff;color:#495057;font-size:.875rem;font-weight:500;text-decoration:none;cursor:pointer;transition:all .2s ease;white-space:nowrap}.qr-actions .btn:hover{background:#f8f9fa;border-color:#adb5bd;transform:translateY(-1px)}.qr-actions .btn:active{transform:translateY(0)}.qr-actions .btn-download{background:linear-gradient(135deg,#28a745,#20c997);color:#fff;border-color:#28a745}.qr-actions .btn-download:hover{background:linear-gradient(135deg,#218838,#1ea77d);border-color:#1e7e34}.qr-actions .btn-copy{background:linear-gradient(135deg,#007bff,#6610f2);color:#fff;border-color:#007bff}.qr-actions .btn-copy:hover{background:linear-gradient(135deg,#0069d9,#520dc2);border-color:#0062cc}.qr-info{text-align:center;color:#495057}.qr-caption{margin:0 0 .25rem;font-size:.9rem;font-weight:500}.qr-url{margin:0;word-break:break-all;color:#6c757d;font-family:Courier New,monospace;font-size:.75rem;line-height:1.4}@media (max-width: 768px){.qr-code-container{padding:1rem;gap:.75rem}.qr-actions{gap:.5rem}.qr-actions .btn{padding:.4rem .8rem;font-size:.8rem}.qr-url{font-size:.7rem}}@media (max-width: 480px){.qr-actions{flex-direction:column;width:100%}.qr-actions .btn{width:100%;justify-content:center}}.overview-page{padding:24px 0;display:flex;flex-direction:column;gap:24px}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}@media (max-width: 1024px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 640px){.stats-grid{grid-template-columns:1fr}}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);padding:20px;text-align:center;box-shadow:var(--shadow-soft);transition:all .2s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-medium)}.stat-title{font-size:13px;font-weight:600;color:var(--muted);margin:0 0 12px}.stat-value{font-size:32px;font-weight:700;color:var(--accent);margin:0 0 8px}.stat-detail{font-size:13px;color:var(--color-text-secondary)}.quick-share{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);padding:20px;box-shadow:var(--shadow-soft)}.quick-share-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.section-title{font-size:18px;font-weight:600;color:var(--text);margin:0}.qr-preview{background:#ffffff;border-radius:8px;padding:8px;box-shadow:0 2px 8px #00000026}.share-options{display:flex;flex-direction:column;gap:16px}.share-item{display:flex;flex-direction:column;gap:8px}.share-label{font-size:13px;font-weight:600;color:var(--color-text-secondary)}.share-input-group{display:flex;gap:8px}.share-input{flex:1;font-size:14px;padding:10px 14px;background:var(--color-background);border:1px solid var(--border);color:var(--text);border-radius:var(--radius-input);font-family:Inter,monospace}.event-code-display{font-weight:600;letter-spacing:.5px;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.btn-copy{padding:10px 16px;font-size:14px;min-width:50px;background:var(--accent);color:var(--color-accent-text);border:none;border-radius:var(--radius-button);cursor:pointer;transition:all .2s ease}.btn-copy:hover{background:var(--color-accent-hover);transform:translateY(-1px)}.recent-activity{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);padding:20px;box-shadow:var(--shadow-soft)}.activity-list{display:flex;flex-direction:column;gap:12px;margin-top:16px}.activity-item{display:flex;align-items:center;gap:12px;padding:12px;background:var(--color-background);border:1px solid var(--border);border-radius:var(--radius-button)}.activity-icon{font-size:20px}.activity-text{font-size:14px;color:var(--text)}@media (max-width: 768px){.overview-page{padding:16px 0}.quick-share-header{flex-direction:column;gap:16px;align-items:flex-start}.share-input-group{flex-direction:column}.btn-copy{width:100%}}.share-qr-page{padding:24px 0;display:flex;flex-direction:column;gap:24px}.qr-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);padding:32px;text-align:center;box-shadow:var(--shadow-soft)}.qr-card h2{font-size:18px;font-weight:600;margin:0 0 24px;color:var(--text)}.qr-container{display:flex;justify-content:center;align-items:center;padding:20px;background:#ffffff;border-radius:12px;margin:0 auto;width:fit-content;box-shadow:0 4px 12px #00000026}.backup-badge{font-size:13px;margin-top:12px;color:var(--muted)}.share-links-section{display:flex;flex-direction:column;gap:20px}.share-input-container{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);padding:20px;box-shadow:var(--shadow-soft)}.share-label{display:block;font-size:14px;font-weight:600;margin-bottom:8px;color:var(--color-text-secondary)}.share-input-group{display:flex;gap:8px;width:100%}.share-input{flex:1;font-family:Inter,monospace;font-size:14px;padding:12px 16px;background:var(--color-background);border:1px solid var(--border);color:var(--text);border-radius:var(--radius-input)}.share-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #7c3aed26}.event-code-large{font-weight:600;letter-spacing:.5px}.btn-copy{white-space:nowrap;padding:12px 20px;font-size:14px;font-weight:600;background:var(--accent);color:var(--color-accent-text);border:none;border-radius:var(--radius-button);cursor:pointer;transition:all .2s ease}.btn-copy:hover{background:var(--color-accent-hover);transform:translateY(-1px);box-shadow:0 4px 12px #7c3aed4d}.share-help{font-size:13px;margin-top:8px;color:var(--muted)}@media (max-width: 768px){.qr-card{padding:24px 16px}.qr-container{padding:16px}.share-input-group{flex-direction:column}.btn-copy{width:100%}}.settings-page{padding:24px 0;position:relative}.settings-grid{display:grid;grid-template-columns:2fr 1fr;gap:24px}@media (max-width: 1024px){.settings-grid{grid-template-columns:1fr}}.settings-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.settings-header h2{font-size:18px;font-weight:600;margin:0;color:var(--text)}.saving-indicator,.saved-indicator{font-size:14px;font-weight:500;display:flex;align-items:center;gap:8px}.saving-indicator{color:var(--muted)}.saved-indicator{color:var(--success)}.spinner-sm{display:inline-block;width:14px;height:14px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.setting-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);padding:20px;margin-bottom:16px;box-shadow:var(--shadow-soft)}.setting-card-title{font-size:15px;font-weight:600;margin:0 0 20px;color:var(--text)}.setting-item{display:flex;justify-content:space-between;align-items:center;padding:16px 0;border-bottom:1px solid var(--border)}.setting-item:last-child{border-bottom:none;padding-bottom:0}.setting-item-vertical{display:flex;flex-direction:column;gap:12px;padding:16px 0;border-bottom:1px solid var(--border)}.setting-item-vertical:last-child{border-bottom:none;padding-bottom:0}.setting-item-full{padding:16px 0;border-bottom:1px solid var(--border)}.setting-item-full:last-child{border-bottom:none;padding-bottom:0}.setting-info{flex:1;padding-right:16px}.setting-label{font-size:14px;font-weight:600;color:var(--text);margin-bottom:4px}.setting-description{font-size:13px;color:var(--muted)}.setting-select{min-width:180px;padding:8px 12px;font-size:14px}.file-types-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px;margin-top:12px}.file-type-checkbox{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text);cursor:pointer;padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius-button);background:var(--color-background);transition:all .2s ease}.file-type-checkbox:hover{border-color:var(--accent);background:var(--surface)}.file-type-checkbox input[type=checkbox]{cursor:pointer}.theme-field{margin-bottom:16px}.theme-field label{display:block;margin-bottom:6px}.color-input{width:100%;height:42px;padding:4px;border:1px solid var(--border);border-radius:var(--radius-input);background:var(--color-background);cursor:pointer}.file-input{font-size:13px;padding:8px;border:1px solid var(--border);border-radius:var(--radius-input);background:var(--color-background);color:var(--text);width:100%}.theme-preview{margin-top:12px;border-radius:var(--radius-card);overflow:hidden}.theme-media{width:100%;max-height:200px;object-fit:cover;border-radius:var(--radius-card)}.autosave-toast{position:fixed;bottom:24px;right:24px;background:var(--surface);border:1px solid var(--border);border-left:4px solid var(--success);border-radius:var(--radius-button);padding:12px 16px;display:flex;align-items:center;gap:8px;box-shadow:var(--shadow-medium);font-size:14px;color:var(--text);z-index:1000;animation:slideIn .3s ease,fadeOut .3s ease 2.7s}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes fadeOut{to{opacity:0;transform:translate(100%)}}.autosave-icon{font-size:16px;color:var(--success)}.autosave-time{font-size:12px;color:var(--muted);margin-left:4px}@media (max-width: 768px){.settings-page{padding:16px 0}.setting-card{padding:16px}.setting-item{flex-direction:column;align-items:flex-start;gap:12px}.setting-info{padding-right:0}.autosave-toast{bottom:16px;right:16px;left:16px}}.album-manager{display:flex;height:100vh;background:#0B0B0D;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.album-manager.loading{justify-content:center;align-items:center}.loading-spinner{text-align:center;color:#9ca3af}.loading-spinner .spinner{width:40px;height:40px;border:4px solid #2A2B30;border-top:4px solid #8b5cf6;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}.error-banner{position:fixed;top:20px;left:50%;transform:translate(-50%);background:#7f1d1d;color:#fecaca;padding:1rem 1.5rem;border:1px solid #991b1b;border-radius:8px;display:flex;align-items:center;gap:.5rem;z-index:1000;box-shadow:0 4px 12px #dc262666;max-width:90%}.error-banner .error-icon{font-size:1.2rem}.error-close{background:none;border:none;color:#fecaca;cursor:pointer;font-size:1.5rem;margin-left:.5rem;padding:0}.albums-sidebar{width:320px;background:#1C1D21;border-right:1px solid #2A2B30;display:flex;flex-direction:column;overflow:hidden}.sidebar-header{padding:1.5rem;border-bottom:1px solid #2A2B30;display:flex;justify-content:space-between;align-items:center}.sidebar-header h3{margin:0;color:#ededed;font-size:1.25rem;font-weight:600}.btn{padding:.5rem 1rem;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;gap:.25rem;text-decoration:none}.btn-primary{background:#8b5cf6;color:#fff}.btn-primary:hover{background:#7c3aed;transform:translateY(-1px)}.btn-secondary{background:#2A2B30;color:#ededed;border:1px solid #3A3B40}.btn-secondary:hover{background:#3A3B40}.btn-sm{padding:.375rem .75rem;font-size:.8rem}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.albums-list{flex:1;overflow-y:auto;padding:1rem}.empty-state{text-align:center;padding:3rem 1rem;color:#9ca3af}.empty-icon{font-size:3rem;margin-bottom:1rem;opacity:.5}.empty-state p{margin:0 0 .5rem;font-size:1.1rem;font-weight:500}.empty-subtitle{font-size:.875rem!important;opacity:.8;font-weight:400!important}.album-item{display:flex;align-items:center;padding:1rem;margin-bottom:.5rem;border:1px solid #2A2B30;border-radius:8px;cursor:pointer;transition:all .2s ease;background:#1C1D21}.album-item:hover{border-color:#8b5cf6;box-shadow:0 2px 8px #8b5cf64d}.album-item.selected{background:#2A2B30;border-color:#8b5cf6;box-shadow:0 2px 8px #8b5cf666}.album-info{flex:1}.album-info h4{margin:0 0 .25rem;color:#ededed;font-size:1rem;font-weight:600}.album-meta{margin:0;font-size:.875rem;color:#9ca3af;display:flex;align-items:center;gap:.5rem}.privacy-badge{font-size:.75rem;padding:.125rem .375rem;background:#7c2d12;color:#fbbf24;border-radius:4px;font-weight:500}.album-actions{display:flex;gap:.25rem;opacity:0;transition:opacity .2s ease}.album-item:hover .album-actions{opacity:1}.btn-icon{background:none;border:none;padding:.375rem;border-radius:4px;cursor:pointer;font-size:.875rem;transition:background-color .2s ease}.btn-icon:hover{background:#f3f4f6}.btn-icon.btn-danger:hover{background:#fef2f2;color:#dc2626}.album-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.album-view{height:100%;display:flex;flex-direction:column}.album-header{padding:1.5rem;border-bottom:1px solid #2A2B30;background:#1C1D21;display:flex;justify-content:space-between;align-items:flex-start}.album-title h2{margin:0 0 .5rem;color:#ededed;font-size:1.5rem;font-weight:700}.album-description{margin:0;color:#9ca3af;font-size:.95rem}.album-stats{display:flex;gap:1rem}.stat{display:flex;align-items:center;gap:.25rem;color:#9ca3af;font-size:.875rem}.stat-icon{font-size:1rem}.media-grid{flex:1;padding:1.5rem;display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;overflow-y:auto;align-content:start}.media-item{background:#1C1D21;border:1px solid #2A2B30;border-radius:8px;overflow:hidden;transition:all .2s ease;cursor:grab}.media-item:hover{box-shadow:0 4px 12px #00000080;transform:translateY(-2px)}.media-item.dragging{transform:rotate(5deg);box-shadow:0 8px 25px #000000b3;cursor:grabbing}.media-thumbnail{position:relative;aspect-ratio:1;overflow:hidden}.media-thumbnail img{width:100%;height:100%;object-fit:cover;transition:transform .2s ease}.media-item:hover .media-thumbnail img{transform:scale(1.05)}.remove-media-btn{position:absolute;top:.5rem;right:.5rem;background:rgba(220,38,38,.9);color:#fff;border:none;width:24px;height:24px;border-radius:50%;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s ease}.media-item:hover .remove-media-btn{opacity:1}.remove-media-btn:hover{background:#dc2626}.media-info{padding:.75rem}.media-filename{margin:0;font-size:.875rem;color:#d1d5db;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.empty-album{grid-column:1 / -1;text-align:center;padding:4rem 2rem;color:#9ca3af}.empty-album .empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.empty-album p{margin:0 0 .5rem;font-size:1.125rem;font-weight:500}.no-album-selected{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:#9ca3af;padding:4rem 2rem}.no-album-selected .empty-icon{font-size:4rem;margin-bottom:1.5rem;opacity:.3}.no-album-selected h3{margin:0 0 .5rem;font-size:1.25rem;font-weight:600}.no-album-selected p{margin:0;font-size:.95rem;opacity:.8}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}.modal{background:#1C1D21;border-radius:12px;max-width:500px;width:90%;max-height:80vh;overflow-y:auto;animation:slideIn .2s ease-out}.modal-header{padding:1.5rem;border-bottom:1px solid #2A2B30;display:flex;justify-content:space-between;align-items:center}.modal-header h3{margin:0;color:#ededed;font-size:1.25rem;font-weight:600}.modal-close{background:none;border:none;color:#9ca3af;cursor:pointer;font-size:1.5rem;padding:0;transition:color .2s ease}.modal-close:hover{color:#d1d5db}.album-form{padding:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:#d1d5db;font-weight:500;font-size:.875rem}.form-group input,.form-group textarea,.form-group select{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;transition:border-color .2s ease;background:#fafbfc}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#8b5cf6;background:#1C1D21;box-shadow:0 0 0 3px #8b5cf640}.form-group textarea{resize:vertical;min-height:80px}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:1.5rem;border-top:1px solid #e5e7eb}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@media (max-width: 768px){.album-manager{flex-direction:column;height:auto;min-height:100vh}.albums-sidebar{width:100%;max-height:40vh;order:2}.album-content{order:1;min-height:60vh}.album-header{flex-direction:column;align-items:flex-start;gap:1rem}.album-stats{align-self:stretch;justify-content:space-between}.media-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.75rem;padding:1rem}.modal{margin:1rem;max-width:none;width:auto}.form-actions{flex-direction:column}.btn{width:100%;justify-content:center}}@media (max-width: 480px){.sidebar-header{padding:1rem}.sidebar-header h3{font-size:1.1rem}.btn-sm{padding:.25rem .5rem;font-size:.75rem}.album-header{padding:1rem}.album-title h2{font-size:1.25rem}.media-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.5rem;padding:.75rem}.album-item,.albums-list{padding:.75rem}}@media (prefers-color-scheme: dark){.album-manager{background:#0f172a}.albums-sidebar,.album-header,.album-item,.media-item,.modal{background:#1e293b;border-color:#334155}.sidebar-header h3,.album-title h2,.album-info h4,.media-filename,.modal-header h3{color:#f1f5f9}.album-meta,.album-description,.stat,.empty-state,.no-album-selected{color:#94a3b8}.form-group label{color:#e2e8f0}.form-group input,.form-group textarea,.form-group select{background:#334155;border-color:#475569;color:#f1f5f9}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{background:#475569;border-color:#3b82f6}.btn-secondary{background:#334155;color:#e2e8f0;border-color:#475569}.btn-secondary:hover{background:#475569}.btn-icon:hover{background:#334155}.modal-close{color:#94a3b8}.modal-close:hover{color:#f1f5f9}}@media (prefers-contrast: high){.album-item,.media-item,.modal,.form-group input,.form-group textarea,.form-group select{border-width:2px}.btn{border-width:2px;border-style:solid}.btn-primary{border-color:#1d4ed8}.btn-secondary{border-color:#9ca3af}}@media (prefers-reduced-motion: reduce){.album-item,.media-item,.btn,.modal-overlay,.modal{transition:none;animation:none}.media-item:hover{transform:none}}.album-item:focus,.btn:focus,.btn-icon:focus,.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:2px solid #3b82f6;outline-offset:2px}@media print{.album-manager{background:white;color:#000}.albums-sidebar{display:none}.album-content{width:100%}.media-grid{display:flex;flex-wrap:wrap;gap:1rem}.media-item{width:200px;border:1px solid #ccc}.remove-media-btn,.album-actions{display:none}}.dashboard-header{background:#1C1D21;border-bottom:1px solid #2A2B30;padding:1.5rem 2rem}.header-content{max-width:1400px;margin:0 auto}.event-info h1{margin:0 0 .5rem;color:#ededed;font-size:1.75rem}.event-date{color:#a0a0a0;font-size:.95rem}.overview-header{display:flex;justify-content:flex-end;margin-bottom:1.5rem}.btn-view-guest-page{padding:.75rem 1.5rem;background:linear-gradient(135deg,#a78bfa,#8b5cf6);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #a78bfa4d}.btn-view-guest-page:hover{transform:translateY(-2px);box-shadow:0 6px 16px #a78bfa66}.albums-tab{display:flex;flex-direction:column;gap:1.5rem}.albums-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:1rem;border-bottom:1px solid #2A2B30}.albums-header h2{margin:0;color:#ededed;font-size:1.5rem}.btn-download-all{padding:.75rem 1.5rem;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #10b9814d}.btn-download-all:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #10b98166}.btn-download-all:disabled{opacity:.5;cursor:not-allowed;transform:none}.dashboard-content{max-width:1400px;margin:0 auto;padding:2rem}.dashboard-content>div{animation:fadeInContent .3s ease}@keyframes fadeInContent{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.dashboard-nav{background:#1C1D21;border-bottom:1px solid #2A2B30;padding:0 2rem;display:flex;gap:.5rem;max-width:1400px;margin:0 auto;overflow-x:auto}.nav-tab{padding:1rem 1.5rem;background:transparent;border:none;border-bottom:3px solid transparent;color:#a0a0a0;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .3s ease;white-space:nowrap}.nav-tab:hover{color:#ededed;background:rgba(167,139,250,.05)}.nav-tab.active{color:#a78bfa;border-bottom-color:#a78bfa;background:rgba(167,139,250,.1)}.stat-card{background:linear-gradient(135deg,#1C1D21 0%,#16171A 100%);border:1px solid #2A2B30;border-radius:12px;padding:1.5rem;transition:all .3s ease;cursor:default}.stat-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0006;border-color:#a78bfa}.stat-card h3{margin:0 0 .75rem;color:#a0a0a0;font-size:.9rem;font-weight:500}.stat-value{font-size:2.5rem;font-weight:700;color:#a78bfa;margin-bottom:.5rem}.stat-detail{font-size:.85rem;color:#6b6b6b}.quick-share{background:#1C1D21;border-radius:12px;padding:1.5rem;border:1px solid #2A2B30;margin-bottom:2rem}.quick-share-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.quick-share-header h3{margin:0;color:#ededed}.qr-preview{flex-shrink:0}.qr-preview .mini-qr{padding:.5rem}.qr-preview .mini-qr .qr-code-container{padding:.75rem;box-shadow:0 2px 6px #0000004d}.qr-preview .mini-qr .qr-actions,.qr-preview .mini-qr .qr-info{display:none}.share-options{display:flex;flex-direction:column;gap:1rem}.share-item{display:flex;flex-direction:column;gap:.5rem}.share-item label{font-weight:600;color:#ededed;font-size:.9rem}.share-input-group{display:flex;gap:.5rem;align-items:stretch}.share-input{flex:1;padding:.75rem 1rem;border:1px solid #2A2B30;border-radius:6px;font-size:.9rem;background:#0B0B0D;color:#ededed;font-family:Courier New,monospace}.share-input:focus{outline:none;border-color:#8b5cf6;box-shadow:0 0 0 2px #8b5cf640}.event-code-input{font-size:1.1rem;font-weight:700;letter-spacing:1px;text-align:center}.btn-copy-sm,.btn-primary-sm,.btn-share-sm{padding:.75rem 1rem;border:none;border-radius:6px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.btn-copy-sm{background:linear-gradient(135deg,#6c757d,#495057);color:#fff}.btn-copy-sm:hover{background:linear-gradient(135deg,#5a6268,#3d4142);transform:translateY(-1px)}.btn-primary-sm{background:linear-gradient(135deg,#007bff,#0056b3);color:#fff}.btn-primary-sm:hover{background:linear-gradient(135deg,#0069d9,#004085);transform:translateY(-1px)}.btn-share-sm{background:linear-gradient(135deg,#28a745,#1e7e34);color:#fff}.btn-share-sm:hover{background:linear-gradient(135deg,#218838,#155724);transform:translateY(-1px)}.share-quick-actions{display:flex;gap:.75rem;margin-top:.5rem;flex-wrap:wrap}.share-tab{display:flex;flex-direction:column;gap:2rem}.share-section{background:#1C1D21;border-radius:12px;padding:2rem;box-shadow:0 4px 12px #0000004d;border:1px solid #2A2B30}.share-section h3{margin:0 0 1.5rem;color:#ededed;font-size:1.25rem;display:flex;align-items:center;gap:.5rem}.qr-section{display:flex;justify-content:center;align-items:center}.share-links{display:flex;flex-direction:column;gap:1.5rem}.share-link-item{display:flex;flex-direction:column;gap:.75rem}.share-link-item label{font-weight:600;color:#ededed;font-size:1rem}.share-input-group{display:flex;gap:.75rem;align-items:stretch}.share-input{flex:1;padding:1rem 1.25rem;border:2px solid #2A2B30;border-radius:8px;font-size:1rem;background:#0B0B0D;color:#ededed;transition:all .2s ease}.share-input:focus{outline:none;border-color:#8b5cf6;background:#1C1D21;box-shadow:0 0 0 3px #8b5cf640}.event-code-large{font-size:1.5rem!important;font-weight:700;letter-spacing:2px;text-align:center;color:#8b5cf6}.share-help{margin:0;color:#9ca3af;font-size:.9rem;font-style:italic}.btn-copy,.btn-share{padding:1rem 1.5rem;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap;display:flex;align-items:center;gap:.5rem}.btn-copy{background:linear-gradient(135deg,#6c757d,#495057);color:#fff}.btn-copy:hover{background:linear-gradient(135deg,#5a6268,#3d4142);transform:translateY(-2px);box-shadow:0 4px 8px #0003}.btn-share{background:linear-gradient(135deg,#17a2b8,#138496);color:#fff}.btn-share:hover{background:linear-gradient(135deg,#138496,#117a8b);transform:translateY(-2px);box-shadow:0 4px 8px #0003}.share-actions{display:flex;gap:1rem;margin-top:1rem;flex-wrap:wrap;justify-content:center}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:#1C1D21;padding:1.5rem;border-radius:12px;box-shadow:0 4px 12px #0000004d;border:1px solid #2A2B30;text-align:center;transition:transform .2s ease,box-shadow .2s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000080}.stat-card h3{margin:0 0 1rem;color:#9ca3af;font-size:1rem;font-weight:600;display:flex;align-items:center;justify-content:center;gap:.5rem}.stat-value{font-size:2.5rem;font-weight:700;color:#8b5cf6;margin-bottom:.5rem;line-height:1}.stat-detail{color:#9ca3af;font-size:.9rem}.dashboard-nav{display:flex;gap:.5rem;margin-bottom:2rem;padding:.5rem;background:#1C1D21;border-radius:10px;overflow-x:auto;border:1px solid #2A2B30}.nav-tab{padding:.75rem 1.25rem;border:none;border-radius:6px;background:transparent;color:#9ca3af;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap;display:flex;align-items:center;gap:.5rem}.nav-tab:hover{background:rgba(139,92,246,.2);color:#8b5cf6}.nav-tab.active{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;box-shadow:0 2px 6px #8b5cf666}.recent-activity{background:#1C1D21;border-radius:12px;padding:1.5rem;box-shadow:0 4px 12px #0000004d;border:1px solid #2A2B30}.recent-activity h3{margin:0 0 1.5rem;color:#ededed;display:flex;align-items:center;gap:.5rem}.activity-list{display:flex;flex-direction:column;gap:1rem}.activity-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:#0B0B0D;border-radius:8px;border-left:4px solid #8b5cf6}.activity-icon{font-size:1.25rem;flex-shrink:0}.activity-text{color:#ededed;font-size:.9rem}@media (max-width: 768px){.quick-share-header{flex-direction:column;align-items:flex-start;gap:1rem}.share-input-group,.share-quick-actions,.share-actions{flex-direction:column}.stats-grid{grid-template-columns:1fr}.dashboard-nav{gap:.25rem}.nav-tab{padding:.6rem 1rem;font-size:.8rem}}@media (max-width: 480px){.qr-preview{display:none}.share-section,.quick-share{padding:1rem}}.install-prompt-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(15,15,35,.85);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px;animation:fadeIn .3s ease-in-out}.install-prompt-container{background:linear-gradient(135deg,#1a1a2e 0%,#16213e 100%);border:1px solid rgba(59,130,246,.3);border-radius:16px;padding:32px;max-width:420px;width:100%;box-shadow:0 20px 60px #00000080;position:relative;animation:slideUp .4s ease-out}.install-prompt-close{position:absolute;top:16px;right:16px;background:rgba(255,255,255,.1);border:none;color:#fff;font-size:20px;width:32px;height:32px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.install-prompt-close:hover{background:rgba(255,255,255,.2);transform:rotate(90deg)}.install-prompt-close:focus{outline:2px solid #3b82f6;outline-offset:2px}.install-prompt-icon{display:flex;justify-content:center;margin-bottom:20px;animation:bounce 2s ease-in-out infinite}.install-prompt-title{font-size:24px;font-weight:700;color:#fff;text-align:center;margin:0 0 12px}.install-prompt-description{font-size:15px;color:#fffc;text-align:center;margin:0 0 24px;line-height:1.5}.install-prompt-features{list-style:none;padding:0;margin:0 0 24px}.install-prompt-features li{display:flex;align-items:center;gap:12px;padding:10px 0;color:#ffffffe6;font-size:14px;border-bottom:1px solid rgba(255,255,255,.1)}.install-prompt-features li:last-child{border-bottom:none}.feature-icon{font-size:20px;width:28px;text-align:center}.install-prompt-button{width:100%;padding:14px 24px;font-size:16px;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;margin-bottom:12px}.install-prompt-button.primary{background:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%);color:#fff;box-shadow:0 4px 12px #3b82f666}.install-prompt-button.primary:hover{background:linear-gradient(135deg,#2563eb 0%,#1d4ed8 100%);box-shadow:0 6px 16px #3b82f699;transform:translateY(-2px)}.install-prompt-button.primary:active{transform:translateY(0)}.install-prompt-button.secondary{background:rgba(255,255,255,.1);color:#fffc;border:1px solid rgba(255,255,255,.2)}.install-prompt-button.secondary:hover{background:rgba(255,255,255,.15);color:#fff}.install-prompt-button:focus{outline:2px solid #3b82f6;outline-offset:2px}.install-prompt-note{font-size:12px;color:#ffffff80;text-align:center;margin:16px 0 0;line-height:1.4}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@media (max-width: 480px){.install-prompt-container{padding:24px;max-width:100%}.install-prompt-title{font-size:20px}.install-prompt-description{font-size:14px}.install-prompt-button{padding:12px 20px;font-size:15px}}@media (prefers-contrast: high){.install-prompt-container{border:2px solid #3b82f6}.install-prompt-button.primary{border:2px solid #fff}.install-prompt-button.secondary{border:2px solid rgba(255,255,255,.6)}}@media (prefers-reduced-motion: reduce){.install-prompt-overlay,.install-prompt-container,.install-prompt-icon,.install-prompt-button{animation:none!important;transition:none!important}.install-prompt-close:hover{transform:none}}@media (prefers-color-scheme: dark){.install-prompt-overlay{background:rgba(15,15,35,.9)}}.legal-page{min-height:100vh;background:linear-gradient(135deg,#0a0b0d 0%,#1a1b1e 100%);color:#e0e0e0;padding:40px 20px}.legal-container{max-width:900px;margin:0 auto;background-color:#1a1b1e;border-radius:12px;box-shadow:0 4px 20px #00000080;overflow:hidden}.legal-header{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);padding:40px 30px;text-align:center;position:relative}.back-link{position:absolute;top:20px;left:30px;color:#fff;text-decoration:none;font-weight:500;transition:opacity .3s ease}.back-link:hover{opacity:.8}.legal-header h1{margin:0 0 10px;color:#fff;font-size:2.5em;font-weight:700}.last-updated{color:#fffc;font-size:.9em;margin:0}.legal-content{padding:50px 40px}.legal-content section{margin-bottom:40px}.legal-content h2{color:#667eea;font-size:1.8em;margin:30px 0 15px;font-weight:600;border-bottom:2px solid #667eea;padding-bottom:10px}.legal-content h3{color:#8b9dc3;font-size:1.3em;margin:25px 0 10px;font-weight:500}.legal-content p{line-height:1.8;margin:15px 0;color:#d0d0d0}.legal-content ul,.legal-content ol{margin:15px 0;padding-left:30px}.legal-content li{margin:10px 0;line-height:1.7;color:#d0d0d0}.legal-content strong{color:#fff;font-weight:600}.legal-content a{color:#667eea;text-decoration:none;border-bottom:1px solid transparent;transition:all .3s ease}.legal-content a:hover{color:#8b9dc3;border-bottom-color:#8b9dc3}.contact-info{background-color:#2a2b2e;border-left:4px solid #667eea;padding:20px 25px;margin:20px 0;border-radius:4px}.contact-info p{margin:8px 0}.info-box{background-color:#2a2b2e;border-left:4px solid #48bb78;padding:20px 25px;margin:20px 0;border-radius:4px}.warning-box{background-color:#3a2a2e;border-left:4px solid #f6ad55;padding:20px 25px;margin:20px 0;border-radius:4px}.legal-footer{background-color:#0f1011;padding:40px 30px;text-align:center;border-top:1px solid #2a2b2e}.legal-links{display:flex;justify-content:center;flex-wrap:wrap;gap:20px;margin-bottom:20px}.legal-links a{color:#667eea;text-decoration:none;font-weight:500;transition:color .3s ease}.legal-links a:hover{color:#8b9dc3}.copyright{color:#888;font-size:.9em;margin:10px 0 0}.legal-content table{width:100%;border-collapse:collapse;margin:20px 0;background-color:#2a2b2e;border-radius:8px;overflow:hidden}.legal-content th{background-color:#667eea;color:#fff;padding:15px;text-align:left;font-weight:600}.legal-content td{padding:15px;border-top:1px solid #3a3b3e;color:#d0d0d0}.legal-content tr:hover{background-color:#242529}.legal-content code{background-color:#2a2b2e;color:#f56565;padding:2px 6px;border-radius:3px;font-family:Courier New,monospace;font-size:.9em}.legal-content pre{background-color:#2a2b2e;padding:20px;border-radius:8px;overflow-x:auto;margin:20px 0}.legal-content pre code{background-color:transparent;padding:0;color:#8b9dc3}@media (max-width: 768px){.legal-page{padding:20px 10px}.legal-container{border-radius:8px}.legal-header{padding:30px 20px}.back-link{position:static;display:block;margin-bottom:15px}.legal-header h1{font-size:2em}.legal-content{padding:30px 20px}.legal-content h2{font-size:1.5em}.legal-content h3{font-size:1.2em}.legal-footer{padding:30px 20px}.legal-links{flex-direction:column;gap:15px}.contact-info,.info-box,.warning-box{padding:15px 20px}}@media (max-width: 480px){.legal-header h1{font-size:1.5em}.legal-content{padding:20px 15px}.legal-content ul,.legal-content ol{padding-left:20px}}@media print{.legal-page{background:white}.legal-container{box-shadow:none;background-color:#fff}.legal-header{background:none;color:#000}.back-link{display:none}.legal-footer{border-top-color:#ccc}.legal-content,.legal-content h2,.legal-content h3,.legal-content a{color:#000}}.upgrade-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000bf;display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px;animation:fadeIn .2s ease-in}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.upgrade-modal-content{background:#ffffff;border-radius:16px;max-width:700px;width:100%;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.upgrade-modal-close{position:absolute;top:20px;right:20px;background:transparent;border:none;font-size:32px;color:#999;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.upgrade-modal-close:hover{background:#f0f0f0;color:#333}.upgrade-modal-header{text-align:center;padding:40px 40px 20px;border-bottom:1px solid #e5e5e5}.upgrade-modal-icon{font-size:64px;margin-bottom:16px;animation:pulse 2s infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.upgrade-modal-header h2{margin:0;font-size:28px;font-weight:700;color:#1a1a1a}.upgrade-modal-body{padding:40px}.upgrade-modal-expiry{text-align:center;font-size:18px;color:#555;margin-bottom:30px;line-height:1.6}.upgrade-modal-expiry strong{color:#e74c3c;font-weight:600}.upgrade-modal-expiry-date{display:block;font-size:14px;color:#999;margin-top:8px}.upgrade-modal-prompt{text-align:center;font-size:16px;color:#666;margin-bottom:40px}.upgrade-modal-plans{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:30px}@media (max-width: 640px){.upgrade-modal-plans{grid-template-columns:1fr}}.upgrade-plan-card{background:#f8f9fa;border:2px solid #e5e5e5;border-radius:12px;padding:24px;text-align:center;position:relative;transition:all .3s}.upgrade-plan-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px #0000001a;border-color:#3498db}.upgrade-plan-card.featured{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-color:#667eea;color:#fff}.upgrade-plan-badge{position:absolute;top:-12px;left:50%;transform:translate(-50%);background:#f39c12;color:#fff;padding:4px 16px;border-radius:12px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.upgrade-plan-card h3{margin:0 0 16px;font-size:24px;font-weight:700;color:#1a1a1a}.upgrade-plan-card.featured h3{color:#fff}.upgrade-plan-price{margin-bottom:24px}.upgrade-plan-price .currency{font-size:20px;vertical-align:top;font-weight:600;color:#666}.upgrade-plan-card.featured .currency{color:#ffffffe6}.upgrade-plan-price .amount{font-size:48px;font-weight:700;color:#1a1a1a}.upgrade-plan-card.featured .amount{color:#fff}.upgrade-plan-price .period{display:block;font-size:14px;color:#999;margin-top:4px}.upgrade-plan-card.featured .period{color:#fffc}.upgrade-plan-features{list-style:none;padding:0;margin:0;text-align:left}.upgrade-plan-features li{padding:8px 0;font-size:14px;color:#555;border-bottom:1px solid #e5e5e5}.upgrade-plan-card.featured .upgrade-plan-features li{color:#fffffff2;border-bottom-color:#fff3}.upgrade-plan-features li:last-child{border-bottom:none}.upgrade-modal-footer{padding:0 40px 30px;display:flex;gap:12px;justify-content:center}@media (max-width: 640px){.upgrade-modal-footer{flex-direction:column}}.upgrade-modal-button{padding:14px 32px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;border:none;transition:all .2s;text-decoration:none;display:inline-block;text-align:center}.upgrade-modal-button.primary{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff}.upgrade-modal-button.primary:hover{transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.upgrade-modal-button.secondary{background:#f0f0f0;color:#666}.upgrade-modal-button.secondary:hover{background:#e5e5e5}.upgrade-modal-note{text-align:center;font-size:13px;color:#999;padding:0 40px 30px;margin:0}@media (max-width: 640px){.upgrade-modal-content{border-radius:12px;max-height:95vh}.upgrade-modal-header{padding:30px 20px 15px}.upgrade-modal-header h2{font-size:24px}.upgrade-modal-icon{font-size:48px}.upgrade-modal-body{padding:30px 20px}.upgrade-modal-expiry{font-size:16px}.upgrade-plan-card{padding:20px}.upgrade-plan-price .amount{font-size:40px}.upgrade-modal-footer,.upgrade-modal-note{padding:0 20px 20px}}:root{--color-background: #0B0B0D;--color-surface: #1C1D21;--color-surface-2: #1C1D21;--color-surface-hover: #25262B;--color-border: #26272E;--color-text-primary: #EDEDED;--color-text-secondary: #9AA0A6;--color-text-muted: #707085;--color-accent: #a78bfa;--color-accent-hover: #9333ea;--color-accent-text: #FFFFFF;--color-success: #22c55e;--color-warning: #f59e0b;--color-danger: #ef4444;--color-info: #60a5fa;--radius-card: 12px;--radius-button: 6px;--radius-input: 6px;--shadow-soft: 0px 4px 20px rgba(0, 0, 0, .25);--shadow-medium: 0px 8px 30px rgba(0, 0, 0, .35);--shadow-strong: 0px 12px 40px rgba(0, 0, 0, .45);--bg: var(--color-background);--surface: var(--color-surface);--surface-2: var(--color-surface-2);--text: var(--color-text-primary);--muted: var(--color-text-secondary);--border: var(--color-border);--accent: var(--color-accent);--primary: var(--color-accent);--success: var(--color-success);--warning: var(--color-warning);--danger: var(--color-danger);--info: var(--color-info);--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--text-sm: 14px;--text-base: 16px;--text-lg: 18px;--text-xl: 20px;--text-2xl: 24px}html,body,#root{background:var(--color-background);color:var(--color-text-primary);font-family:var(--font-sans);min-height:100%;margin:0;padding:0}*{box-sizing:border-box}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-card);box-shadow:var(--shadow-soft);transition:all .2s ease}.card:hover{background:var(--color-surface-hover);box-shadow:var(--shadow-medium)}.btn{border-radius:var(--radius-button);padding:12px 24px;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-primary);cursor:pointer;text-decoration:none;display:inline-block;font-family:var(--font-sans);font-size:16px;font-weight:600;transition:all .2s ease}.btn:hover{background:var(--color-surface-hover);border-color:var(--color-text-muted)}.btn.primary{background:var(--color-accent);color:var(--color-accent-text);border:none}.btn.primary:hover{background:var(--color-accent-hover);transform:translateY(-1px);box-shadow:var(--shadow-soft)}.btn.ghost{background:transparent;border-color:var(--color-border)}.btn.ghost:hover{background:var(--color-surface);border-color:var(--color-text-muted)}.input,.select,textarea{background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text-primary);border-radius:var(--radius-input);padding:12px 16px;width:100%;font-family:var(--font-sans);font-size:16px;transition:all .2s ease}.input:focus,.select:focus,textarea:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #ffffff1a}.input::placeholder{color:var(--color-text-muted)}.badge{background:var(--color-surface);color:var(--color-text-secondary);padding:6px 12px;border-radius:999px;font-size:14px;font-weight:600;display:inline-block;border:1px solid var(--color-border)}.hero-section{background:var(--color-background);min-height:100vh;padding:var(--space-xl)}.surface{background:var(--surface)}.surface-2{background:var(--surface-2)}.text-default{color:var(--text)}.text-secondary{color:var(--color-text-secondary)}.text-muted{color:var(--color-text-muted)}.border-default{border-color:var(--border)}.text-center{text-align:center}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.gap-4{gap:16px}.gap-2{gap:8px}.p-4{padding:16px}.p-6{padding:24px}.mt-4{margin-top:16px}.mb-4{margin-bottom:16px}.w-full{width:100%}.max-w-lg{max-width:32rem}.max-w-4xl{max-width:56rem}.mx-auto{margin-left:auto;margin-right:auto}.grid{display:grid}.grid-cols-1{grid-template-columns:repeat(1,1fr)}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}@media (max-width: 768px){.grid-cols-3{grid-template-columns:repeat(1,1fr)}.grid-cols-4{grid-template-columns:repeat(2,1fr)}}.switch:focus{outline:2px solid rgba(91,140,255,.45);outline-offset:2px}::-webkit-scrollbar{width:12px;height:12px}::-webkit-scrollbar-track{background:var(--color-background)}::-webkit-scrollbar-thumb{background:var(--color-surface);border-radius:6px;border:2px solid var(--color-background)}::-webkit-scrollbar-thumb:hover{background:var(--color-surface-hover)}*{scrollbar-width:thin;scrollbar-color:var(--color-surface) var(--color-background)}input:-webkit-autofill,input:-webkit-autofill:hover,input:-webkit-autofill:focus,textarea:-webkit-autofill,textarea:-webkit-autofill:hover,textarea:-webkit-autofill:focus,select:-webkit-autofill,select:-webkit-autofill:hover,select:-webkit-autofill:focus{-webkit-text-fill-color:var(--color-text-primary);-webkit-box-shadow:0 0 0px 1000px var(--color-surface) inset;transition:background-color 5000s ease-in-out 0s}:root{--color-cream-bg: #FFFCF7;--color-gold-accent: #CA985A;--color-text-charcoal: #4A3F35;--color-gold-hover: #B88748;--color-gold-light: rgba(202, 152, 90, .15);--color-gold-border: rgba(202, 152, 90, .3);--color-bg-gradient: linear-gradient(135deg, #FFFCF7 0%, #FFF9F1 100%);--color-text-main: #4A3F35;--color-text-subtext: #6B5D54;--color-text-muted: #9A8A7F;--color-card-bg: rgba(255, 255, 255, .9);--color-card-bg-hover: rgba(255, 255, 255, .95);--color-card-border: rgba(202, 152, 90, .2);--color-input-bg: rgba(255, 255, 255, .95);--color-input-border: rgba(202, 152, 90, .3);--color-success: #9FA796;--color-warning: #E8B44A;--color-error: #C97064;--color-info: #A2B5BB;--font-headings: "Playfair Display", Georgia, serif;--font-subheadings: "Cormorant Garamond", Georgia, serif;--font-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-weight-heading: 600;--font-weight-body: 400;--line-height-heading: 1.4;--line-height-body: 1.75;--spacing-xs: 12px;--spacing-sm: 20px;--spacing-md: 32px;--spacing-lg: 48px;--spacing-xl: 72px;--spacing-xxl: 108px;--radius-sm: 8px;--radius-md: 10px;--radius-lg: 12px}*{margin:0;padding:0;box-sizing:border-box}html{min-height:100vh;background:var(--color-cream-bg)}body{font-family:var(--font-body);font-weight:var(--font-weight-body);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--color-cream-bg);background-attachment:fixed;color:var(--color-text-main);line-height:var(--line-height-body);min-height:100vh;font-size:16px;letter-spacing:.2px}#root{min-height:100vh;background:var(--color-cream-bg)}h1,h2,h3,h4,h5,h6{font-family:var(--font-headings);font-weight:var(--font-weight-heading);line-height:var(--line-height-heading);color:var(--color-text-main);letter-spacing:-.3px}h1{font-size:3rem;margin-bottom:var(--spacing-md)}h2{font-size:2.25rem;margin-bottom:var(--spacing-sm)}h3{font-size:1.75rem;margin-bottom:var(--spacing-sm)}.app{min-height:100vh;display:flex;flex-direction:column;background:var(--color-bg-gradient)}.app-header{background:var(--color-card-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--color-card-border);padding:1rem 2rem;box-shadow:0 4px 20px #0000004d}.header-content{max-width:1440px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;padding:0 2rem}.app-header h1{font-size:2rem;font-weight:var(--font-weight-heading);line-height:var(--line-height-heading);color:var(--color-text-main);text-shadow:var(--color-primary-glow)}.app-header p{color:var(--color-text-subtext);font-size:1.1rem}.system-status{padding:.25rem .75rem;border-radius:9999px;font-size:.875rem;font-weight:600}.system-status.ok{background:rgba(74,222,128,.2);color:var(--color-success);border:1px solid var(--color-success)}.system-status.error{background:rgba(239,68,68,.2);color:var(--color-error);border:1px solid var(--color-error)}.app-main{flex:1;padding:2rem;max-width:1440px;margin:0 auto;width:100%}.app-footer{background:var(--color-card-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:var(--color-text-subtext);padding:1rem 2rem;text-align:center;border-top:1px solid var(--color-card-border)}.footer-content{max-width:1440px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;font-size:.875rem;padding:0 2rem}.home-view{text-align:center;max-width:600px;margin:0 auto}.welcome-section{margin-bottom:3rem}.welcome-section h2{font-size:2.5rem;margin-bottom:1rem;color:#1e293b}.welcome-section p{font-size:1.2rem;color:#64748b;line-height:1.8}.action-buttons{display:flex;flex-direction:column;gap:2rem;align-items:center}.join-section{width:100%}.join-input-group{display:flex;gap:.5rem;margin-top:1rem}.join-input-group input{flex:1;padding:.75rem 1rem;border:1px solid #cbd5e1;border-radius:8px;font-size:1rem}.error-banner{background:rgba(239,68,68,.1);border:1px solid var(--color-error);color:var(--color-error);padding:1rem;border-radius:8px;margin-top:2rem}.btn{padding:14px 32px;border:1.5px solid var(--color-gold-accent);border-radius:var(--radius-md);font-family:var(--font-body);font-size:.9rem;font-weight:500;letter-spacing:.5px;color:var(--color-gold-accent);background:transparent;cursor:pointer;transition:all .35s cubic-bezier(.4,0,.2,1);text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:8px;position:relative}.btn:hover:not(:disabled){background:var(--color-gold-light);box-shadow:0 0 20px #ca985a66;transform:translateY(-1px)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--color-gold-accent);color:#fff;border-color:var(--color-gold-accent)}.btn-primary:hover:not(:disabled){background:var(--color-gold-hover);border-color:var(--color-gold-hover);box-shadow:0 0 25px #ca985a80}.btn-secondary{background:transparent;color:var(--color-gold-accent);border:1.5px solid var(--color-gold-accent)}.btn-secondary:hover:not(:disabled){background:var(--color-gold-light);box-shadow:0 0 20px #ca985a4d}.btn-back{background:var(--color-card-bg);color:var(--color-text-subtext);border:1px solid var(--color-card-border)}.btn-back:hover:not(:disabled){background:var(--color-card-bg-hover);color:var(--color-text-main)}.btn-large{padding:1rem 2rem;font-size:1.1rem}.event-creator{max-width:500px;margin:0 auto}.creator-header{margin-bottom:2rem}.event-form{background:var(--color-card-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:2rem;border-radius:12px;box-shadow:0 8px 32px #0000004d;border:1px solid var(--color-card-border)}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:var(--color-text-main)}.form-group input,.form-group textarea{width:100%;padding:.75rem 1rem;border:1px solid var(--color-input-border);background:var(--color-input-bg);color:var(--color-text-main);border-radius:8px;font-size:1rem;transition:all .3s ease;font-family:var(--font-primary)}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #7b61ff1a}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--color-text-muted)}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.char-count{text-align:right;font-size:.875rem;color:#6b7280;margin-top:.25rem}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.form-info{margin-top:1.5rem;padding:1rem;background:#f0f9ff;border-radius:8px;font-size:.875rem;color:#0369a1}.error-message{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:1rem;border-radius:8px;margin-bottom:1.5rem}.event-gallery{max-width:1200px;margin:0 auto}.gallery-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.event-info h2{font-size:2rem;color:#1e293b;margin-bottom:.5rem}.event-meta{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}.event-code{background:#f1f5f9;padding:.25rem .75rem;border-radius:6px;cursor:pointer;transition:background .2s ease}.event-code:hover{background:#e2e8f0}.media-stats{background:#3b82f6;color:#fff;padding:.5rem 1rem;border-radius:9999px;font-weight:600}.upload-area{border:2px dashed #cbd5e1;border-radius:12px;padding:3rem 2rem;text-align:center;margin-bottom:2rem;transition:all .3s ease;background:white}.upload-area.drag-over{border-color:#3b82f6;background:#f0f9ff;transform:scale(1.02)}.upload-area.uploading{border-style:solid;border-color:#3b82f6}.upload-content{pointer-events:none}.upload-area:not(.uploading) .upload-content{pointer-events:auto}.upload-icon{font-size:3rem;margin-bottom:1rem}.upload-hint{font-size:.875rem;color:#64748b;margin-top:.5rem}.upload-progress{width:100%;height:8px;background:#e2e8f0;border-radius:4px;overflow:hidden;margin-bottom:1rem}.progress-bar{height:100%;background:#3b82f6;transition:width .3s ease}.media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;margin-bottom:2rem}.media-card{background:white;border-radius:12px;overflow:hidden;box-shadow:0 4px 6px -1px #0000001a;transition:transform .2s ease,box-shadow .2s ease}.media-card:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a}.media-card img,.media-card video{width:100%;height:200px;object-fit:cover;display:block}.media-info{padding:1rem}.filename{font-weight:600;color:#1e293b;display:block;margin-bottom:.5rem;word-break:break-word}.meta-details{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;font-size:.875rem}.uploader{color:#3b82f6;font-weight:600}.file-size{color:#64748b}.upload-time{font-size:.75rem;color:#94a3b8}.empty-state{text-align:center;padding:4rem 2rem;color:#64748b}.empty-icon{font-size:4rem;margin-bottom:1rem}.app-loading,.loading-content{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:1rem}.loading-spinner{width:40px;height:40px;border:4px solid #e2e8f0;border-left:4px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.connection-status{position:fixed;bottom:1rem;right:1rem;background:white;padding:.5rem 1rem;border-radius:9999px;box-shadow:0 4px 6px -1px #0000001a;font-size:.875rem;font-weight:600}.error-content{text-align:center;padding:4rem 2rem}.error-content h2{color:#dc2626;margin-bottom:1rem}.error-boundary{padding:2rem;text-align:center;min-height:400px;display:flex;align-items:center;justify-content:center}.error-boundary .error-content{background:white;padding:2rem;border-radius:8px;border:2px solid #ef4444;max-width:600px;width:100%}.error-boundary .error-content h2{color:#dc2626;margin-bottom:1rem;font-size:1.5rem}.error-boundary .error-content p{color:#64748b;margin-bottom:2rem}.error-actions{display:flex;gap:1rem;justify-content:center;margin-bottom:2rem}.error-details{margin-top:2rem;text-align:left;border:1px solid #e2e8f0;border-radius:4px;padding:1rem;background:#f8fafc}.error-details summary{cursor:pointer;font-weight:600;color:#374151;margin-bottom:1rem}.error-stack{background:#f1f5f9;padding:1rem;border-radius:4px;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.875rem;color:#374151;white-space:pre-wrap;overflow-x:auto}@media (max-width: 768px){.app-main{padding:1rem}.header-content{flex-direction:column;text-align:center;gap:.5rem}.gallery-header{flex-direction:column;align-items:flex-start}.media-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}.footer-content{flex-direction:column;text-align:center}.form-actions,.join-input-group{flex-direction:column}}@media (max-width: 480px){.media-grid{grid-template-columns:1fr}.app-header h1{font-size:1.5rem}.welcome-section h2{font-size:2rem}}.logo-text-mobile{display:none}@media (max-width: 768px){.logo-text-mobile{display:inline}}.navbar-logo{height:54px;width:auto;display:block;filter:drop-shadow(0px 2px 4px rgba(74,63,53,.25))}@media (max-width: 1024px){.navbar-logo{height:48px}}@media (max-width: 768px){.navbar-logo{height:42px}}nav,.navbar{background-color:#fffcf7!important}
