*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{background:var(--bg-base);color:var(--text-primary);min-height:100vh;font-family:Inter,system-ui,-apple-system,sans-serif;line-height:1.6}img{max-width:100%;display:block}button{cursor:pointer;font-family:inherit}a{color:inherit;text-decoration:none}input,textarea,select{font-family:inherit;font-size:inherit}ul,ol{list-style:none}:root{--bg-base:#07070d;--bg-surface:#0e0e18;--bg-elevated:#151524;--bg-hover:#1c1c30;--bg-glass:#1414288c;--accent:#6347eb;--accent-hover:#826cef;--accent-muted:#2a2060;--accent-glow:#6e50f040;--accent-secondary:#25aff4;--success:#22c380;--warning:#f4af25;--danger:#e23636;--info:#4799eb;--text-primary:#e9e9ed;--text-secondary:#9191a1;--text-muted:#60606c;--text-inverse:#07070d;--border:#292932;--border-hover:#40404f;--border-accent:#3d29a3;--space-xs:.25rem;--space-sm:.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:3rem;--space-3xl:4rem;--radius-sm:.375rem;--radius-md:.625rem;--radius-lg:1rem;--radius-xl:1.25rem;--radius-full:9999px;--shadow-sm:0 1px 3px #0006;--shadow-md:0 4px 12px #00000080;--shadow-lg:0 8px 30px #0009;--shadow-glow:0 0 20px var(--accent-glow);--sidebar-w:260px;--header-h:64px;--transition:all .2s cubic-bezier(.4,0,.2,1)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--border-hover)}h1{letter-spacing:-.02em;font-size:1.75rem;font-weight:700}h2{letter-spacing:-.01em;font-size:1.375rem;font-weight:600}h3{font-size:1.125rem;font-weight:600}h4{font-size:1rem;font-weight:500}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-muted{color:var(--text-secondary)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes slideInRight{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:translate(0)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes progressStripe{0%{background-position:1rem 0}to{background-position:0 0}}.animate-fade{animation:.4s ease-out both fadeIn}.animate-scale{animation:.3s ease-out both fadeInScale}.animate-slide{animation:.35s ease-out both slideInRight}.animate-slide-up{animation:.4s ease-out both slideUp}.glass{background:var(--bg-glass);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border);border-radius:var(--radius-lg)}.auth-page{background:radial-gradient(ellipse at 30% 20%,#120c31 0%,var(--bg-base) 70%);justify-content:center;align-items:center;min-height:100vh;display:flex}.auth-card{width:100%;max-width:420px;padding:var(--space-2xl);animation:.5s ease-out fadeInScale}.auth-logo{text-align:center;margin-bottom:var(--space-xl)}.auth-logo h1{background:linear-gradient(135deg,var(--accent),var(--accent-secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:2rem;font-weight:800}.auth-logo p{color:var(--text-secondary);margin-top:var(--space-xs);font-size:.875rem}.form-group{margin-bottom:var(--space-lg)}.form-group label{color:var(--text-secondary);margin-bottom:var(--space-xs);text-transform:uppercase;letter-spacing:.05em;font-size:.8125rem;font-weight:500;display:block}.form-input{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);width:100%;color:var(--text-primary);transition:var(--transition);outline:none;padding:.75rem 1rem;font-size:.9375rem}.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.form-input::placeholder{color:var(--text-muted)}.form-error{color:var(--danger);margin-top:var(--space-xs);font-size:.8125rem}.btn{border-radius:var(--radius-md);transition:var(--transition);white-space:nowrap;border:none;justify-content:center;align-items:center;gap:.5rem;padding:.6875rem 1.25rem;font-size:.875rem;font-weight:500;display:inline-flex}.btn:disabled{opacity:.5;pointer-events:none}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover);box-shadow:var(--shadow-glow)}.btn-secondary{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--border-hover)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#e75555}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-sm{padding:.4375rem .75rem;font-size:.8125rem}.btn-lg{padding:.8125rem 1.75rem;font-size:1rem}.btn-icon{border-radius:var(--radius-sm);padding:.5rem}.btn-full{width:100%}.badge{border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.04em;align-items:center;gap:.25rem;padding:.1875rem .625rem;font-size:.6875rem;font-weight:600;display:inline-flex}.badge-success{color:var(--success);background:#22c38026}.badge-warning{color:var(--warning);background:#f4af2526}.badge-danger{color:var(--danger);background:#e2363626}.badge-info{color:var(--info);background:#4799eb26}.badge-accent{background:var(--accent-muted);color:var(--accent-hover)}.spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:20px;height:20px;animation:.6s linear infinite spin;display:inline-block}.spinner-lg{border-width:3px;width:32px;height:32px}.dashboard{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-w);background:var(--bg-surface);border-right:1px solid var(--border);z-index:40;flex-direction:column;transition:transform .3s;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-header{padding:var(--space-lg) var(--space-lg) var(--space-md);border-bottom:1px solid var(--border)}.sidebar-brand{background:linear-gradient(135deg,var(--accent),var(--accent-secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.25rem;font-weight:800}.sidebar-nav{padding:var(--space-md) var(--space-sm);flex:1;overflow-y:auto}.sidebar-link{border-radius:var(--radius-md);color:var(--text-secondary);transition:var(--transition);align-items:center;gap:.75rem;margin-bottom:2px;padding:.625rem .875rem;font-size:.875rem;font-weight:500;display:flex}.sidebar-link:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar-link.active{background:var(--accent-muted);color:var(--accent-hover)}.sidebar-link.active svg{color:var(--accent)}.sidebar-link svg{flex-shrink:0;width:18px;height:18px}.sidebar-footer{padding:var(--space-md) var(--space-lg);border-top:1px solid var(--border)}.sidebar-user{align-items:center;gap:.75rem;display:flex}.sidebar-avatar{border-radius:var(--radius-full);background:var(--accent-muted);width:36px;height:36px;color:var(--accent);justify-content:center;align-items:center;font-size:.875rem;font-weight:600;display:flex}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.8125rem;font-weight:600;overflow:hidden}.sidebar-user-role{color:var(--text-muted);text-transform:capitalize;font-size:.6875rem}.main-content{margin-left:var(--sidebar-w);flex:1;min-height:100vh}.page-header{padding:var(--space-lg) var(--space-xl);border-bottom:1px solid var(--border);background:var(--bg-surface);z-index:30;-webkit-backdrop-filter:blur(12px);justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.page-header h1{font-size:1.375rem}.page-body{padding:var(--space-xl)}.card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);transition:var(--transition);overflow:hidden}.card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-md)}.card-body{padding:var(--space-lg)}.card-footer{padding:var(--space-md) var(--space-lg);border-top:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}.events-grid{gap:var(--space-lg);grid-template-columns:repeat(auto-fill,minmax(320px,1fr));display:grid}.event-card{cursor:pointer;position:relative}.event-card:before{content:"";border-radius:var(--radius-lg);background:linear-gradient(135deg,var(--accent-glow),transparent);opacity:0;pointer-events:none;transition:opacity .3s;position:absolute;inset:0}.event-card:hover:before{opacity:1}.event-card-header{margin-bottom:var(--space-md);justify-content:space-between;align-items:flex-start;display:flex}.event-card-title{color:var(--text-primary);font-size:1.0625rem;font-weight:600}.event-card-date{color:var(--text-secondary);margin-top:var(--space-xs);font-size:.8125rem}.event-card-stats{gap:var(--space-lg);margin-top:var(--space-md);display:flex}.event-stat{text-align:center}.event-stat-value{color:var(--text-primary);font-size:1.25rem;font-weight:700}.event-stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.6875rem}.image-grid{gap:var(--space-sm);grid-template-columns:repeat(auto-fill,minmax(180px,1fr));display:grid}.image-card{border-radius:var(--radius-md);aspect-ratio:1;cursor:pointer;transition:var(--transition);position:relative;overflow:hidden}.image-card:hover{transform:scale(1.02)}.image-card img{object-fit:cover;width:100%;height:100%}.image-card-overlay{opacity:0;padding:var(--space-sm);background:linear-gradient(#0000 50%,#0009 100%);align-items:flex-end;transition:opacity .2s;display:flex;position:absolute;inset:0}.image-card:hover .image-card-overlay{opacity:1}.image-card-check{top:var(--space-sm);left:var(--space-sm);border-radius:var(--radius-sm);width:22px;height:22px;transition:var(--transition);background:#0000004d;border:2px solid #fff9;justify-content:center;align-items:center;display:flex;position:absolute}.image-card-check.checked{background:var(--accent);border-color:var(--accent)}.image-card-check svg{color:#fff;width:14px;height:14px}.image-card.selected{outline:2px solid var(--accent);outline-offset:2px}.dropzone{border:2px dashed var(--border);border-radius:var(--radius-lg);padding:var(--space-2xl);text-align:center;cursor:pointer;transition:var(--transition);flex-direction:column;justify-content:center;align-items:center;min-height:200px;display:flex}.dropzone:hover,.dropzone.drag-over{border-color:var(--accent);background:#6e50f00d}.dropzone svg{width:48px;height:48px;color:var(--text-muted);margin-bottom:var(--space-md)}.dropzone-text{color:var(--text-secondary);font-size:.9375rem}.dropzone-text strong{color:var(--accent)}.upload-list{gap:var(--space-sm);margin-top:var(--space-lg);flex-direction:column;display:flex}.upload-item{align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--bg-elevated);border-radius:var(--radius-md);animation:.3s ease-out both fadeIn;display:flex}.upload-item-info{flex:1;min-width:0}.upload-item-name{white-space:nowrap;text-overflow:ellipsis;font-size:.8125rem;font-weight:500;overflow:hidden}.upload-item-size{color:var(--text-muted);font-size:.6875rem}.upload-item-status{font-size:.75rem;font-weight:500}.upload-item-status.pending{color:var(--text-muted)}.upload-item-status.uploading{color:var(--info)}.upload-item-status.processing{color:var(--warning)}.upload-item-status.ready{color:var(--success)}.upload-item-status.failed{color:var(--danger)}.progress-bar{background:var(--bg-hover);border-radius:var(--radius-full);width:100%;height:4px;overflow:hidden}.progress-bar-fill{background:linear-gradient(90deg,var(--accent),var(--accent-secondary));border-radius:var(--radius-full);height:100%;transition:width .3s}.progress-bar-striped .progress-bar-fill{background-image:linear-gradient(45deg,#ffffff1a 25%,#0000 25% 50%,#ffffff1a 50% 75%,#0000 75%);background-size:1rem 1rem;animation:.5s linear infinite progressStripe}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#0009;justify-content:center;align-items:center;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);width:90%;max-width:540px;max-height:85vh;box-shadow:var(--shadow-lg);animation:.25s ease-out fadeInScale;overflow:auto}.modal-header{padding:var(--space-lg);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}.modal-header h2{font-size:1.125rem}.modal-body{padding:var(--space-lg)}.modal-footer{padding:var(--space-md) var(--space-lg);border-top:1px solid var(--border);justify-content:flex-end;gap:var(--space-sm);display:flex}.toast-container{top:var(--space-lg);right:var(--space-lg);z-index:200;gap:var(--space-sm);flex-direction:column;display:flex;position:fixed}.toast{padding:var(--space-md) var(--space-lg);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);align-items:center;gap:var(--space-sm);min-width:280px;font-size:.875rem;font-weight:500;animation:.3s ease-out slideInRight;display:flex}.toast-success{border:1px solid var(--success);color:var(--success);background:#124932}.toast-error{border:1px solid var(--danger);color:var(--danger);background:#391313}.toast-info{border:1px solid var(--info);color:var(--info);background:#132639}.tabs{border-bottom:1px solid var(--border);margin-bottom:var(--space-lg);gap:0;display:flex}.tab{padding:var(--space-md) var(--space-lg);color:var(--text-secondary);transition:var(--transition);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;font-size:.875rem;font-weight:500}.tab:hover{color:var(--text-primary)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.empty-state{padding:var(--space-3xl);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-state svg{width:64px;height:64px;color:var(--text-muted);margin-bottom:var(--space-lg)}.empty-state h3{color:var(--text-primary);margin-bottom:var(--space-sm)}.empty-state p{color:var(--text-secondary);max-width:360px;font-size:.875rem}.ws-status{align-items:center;gap:var(--space-sm);color:var(--text-muted);font-size:.75rem;display:flex}.ws-dot{border-radius:50%;width:8px;height:8px}.ws-dot.connected{background:var(--success);box-shadow:0 0 6px var(--success)}.ws-dot.disconnected{background:var(--danger)}.ws-dot.connecting{background:var(--warning);animation:1.5s infinite pulse}.section-header{margin-bottom:var(--space-lg);justify-content:space-between;align-items:center;display:flex}.skeleton{background:linear-gradient(90deg,var(--bg-elevated) 25%,var(--bg-hover) 50%,var(--bg-elevated) 75%);border-radius:var(--radius-md);background-size:200% 100%;animation:1.5s infinite shimmer}.media-preview{aspect-ratio:16/9;border-radius:var(--radius-md);background:var(--bg-elevated);justify-content:center;align-items:center;width:100%;display:flex;overflow:hidden}.media-preview img{object-fit:contain;width:100%;height:100%}.stats-grid{gap:var(--space-lg);margin-bottom:var(--space-xl);grid-template-columns:repeat(auto-fill,minmax(200px,1fr));display:grid}.stat-card{padding:var(--space-lg)}.stat-card-value{background:linear-gradient(135deg,var(--accent),var(--accent-secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:2rem;font-weight:700}.stat-card-label{color:var(--text-secondary);margin-top:var(--space-xs);font-size:.8125rem}.media-grid{gap:var(--space-lg);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.media-tile{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);flex-direction:column;display:flex;overflow:hidden}.media-tile-header{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}.media-tile-title{color:var(--text-primary);align-items:center;gap:.5rem;font-size:.9375rem;font-weight:600;display:flex}.media-tile-preview{aspect-ratio:16/9;background:var(--bg-elevated);justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.media-tile-preview img{object-fit:contain;background:repeating-conic-gradient(var(--bg-hover) 0% 25%,transparent 0% 50%) 50% / 16px 16px;width:100%;height:100%}.media-tile-empty{color:var(--text-muted);padding:var(--space-lg);flex-direction:column;align-items:center;gap:.5rem;font-size:.8125rem;display:flex}.media-tile-empty svg{width:32px;height:32px}.media-tile-actions{padding:var(--space-md) var(--space-lg);border-top:1px solid var(--border);background:var(--bg-surface);gap:.5rem;display:flex}.media-tile-actions .btn{flex:1}.gallery-public-header{border-radius:var(--radius-lg);margin-bottom:var(--space-xl);background:var(--bg-elevated);align-items:flex-end;min-height:220px;display:flex;position:relative;overflow:hidden}.gallery-public-hero{filter:brightness(.55);background-position:50%;background-size:cover;position:absolute;inset:0}.gallery-public-hero.placeholder{background:linear-gradient(135deg,var(--accent-muted),var(--bg-elevated))}.gallery-public-content{z-index:1;padding:var(--space-xl);align-items:center;gap:var(--space-lg);width:100%;display:flex;position:relative}.gallery-public-logo{border-radius:var(--radius-md);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff14;border:1px solid #ffffff26;flex-shrink:0;justify-content:center;align-items:center;width:72px;height:72px;display:flex;overflow:hidden}.gallery-public-logo img{object-fit:contain;width:100%;height:100%}.gallery-public-info h2{color:#fff;text-shadow:0 2px 12px #0009;font-size:1.5rem}.gallery-public-info p{color:#ffffffd9;margin-top:.25rem;font-size:.8125rem}.gallery-public-badge{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius-full);color:#fff;text-transform:uppercase;letter-spacing:.05em;background:#00000073;border:1px solid #ffffff26;margin-left:auto;padding:.375rem .75rem;font-size:.6875rem}.gallery-public-cover{top:var(--space-md);right:var(--space-md);border-radius:var(--radius-md);width:64px;height:64px;box-shadow:var(--shadow-md);z-index:2;border:2px solid #ffffff40;position:absolute;overflow:hidden}.gallery-public-cover img{object-fit:cover;width:100%;height:100%}.warning-banner{padding:var(--space-md) var(--space-lg);border-radius:var(--radius-md);color:var(--warning);margin-bottom:var(--space-lg);background:#f4af2514;border:1px solid #f4af2559;align-items:center;gap:.75rem;font-size:.875rem;display:flex}.warning-banner svg{flex-shrink:0}.warning-banner button{border:1px solid var(--warning);color:var(--warning);border-radius:var(--radius-sm);background:0 0;margin-left:auto;padding:.25rem .625rem;font-size:.75rem;font-weight:500}.warning-banner button:hover{background:#f4af2526}@media (width<=768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0}.page-body{padding:var(--space-md)}.events-grid{grid-template-columns:1fr}.image-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.stats-grid{grid-template-columns:1fr 1fr}}
