@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";
:root{--bg-primary:#0a0a0f;--bg-secondary:#12121a;--bg-card:#1a1a2e;--bg-card-hover:#22223a;--bg-elevated:#252540;--bg-input:#16162a;--accent-primary:#6c5ce7;--accent-secondary:#a29bfe;--accent-gradient:linear-gradient(135deg,#6c5ce7,#a29bfe);--accent-glow:0 0 20px #6c5ce74d;--success:#00d2d3;--success-bg:#00d2d31a;--warning:#feca57;--warning-bg:#feca571a;--danger:#ff6b6b;--danger-bg:#ff6b6b1a;--info:#54a0ff;--info-bg:#54a0ff1a;--text-primary:#e8e8f0;--text-secondary:#9898b0;--text-muted:#5a5a7a;--text-accent:#a29bfe;--border-default:#ffffff0f;--border-hover:#ffffff1f;--border-accent:#6c5ce74d;--glass-bg:#1a1a2ecc;--glass-border:#ffffff14;--glass-shadow:0 8px 32px #0000004d;--sidebar-width:260px;--header-height:64px;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:20px;--transition-fast:.15s ease;--transition-normal:.25s ease;--transition-slow:.4s ease}[data-theme=light]{--bg-primary:#f0f0f8;--bg-secondary:#fff;--bg-card:#fff;--bg-card-hover:#f5f5ff;--bg-elevated:#f8f8ff;--bg-input:#f0f0f8;--accent-primary:#5b4cdb;--accent-secondary:#7c6ff0;--accent-gradient:linear-gradient(135deg,#5b4cdb,#7c6ff0);--accent-glow:0 0 20px #5b4cdb26;--success:#00a8a8;--success-bg:#00a8a81a;--warning:#d49700;--warning-bg:#d497001a;--danger:#dc3545;--danger-bg:#dc354514;--info:#2563eb;--info-bg:#2563eb14;--text-primary:#1a1a2e;--text-secondary:#5a5a7a;--text-muted:#9898b0;--text-accent:#5b4cdb;--border-default:#00000014;--border-hover:#00000026;--border-accent:#5b4cdb40;--glass-bg:#ffffffe6;--glass-border:#0000000f;--glass-shadow:0 4px 24px #0000000f}[data-theme-transition] *{transition:background-color .3s,color .2s,border-color .3s,box-shadow .3s!important}[data-theme=light] .badge-archived{color:var(--text-muted);background:#0000000d}[data-theme=light] .badge-member{color:var(--text-secondary);background:#0000000d}[data-theme=light] .data-table tr:hover td{background:#00000005}[data-theme=light] .login-branding{background:#5b4cdb08}[data-theme=light] .login-branding-orb-1{background:radial-gradient(circle,#5b4cdb0f 0%,#0000 70%)}[data-theme=light] .login-branding-orb-2{background:radial-gradient(circle,#7c6ff00a 0%,#0000 70%)}[data-theme=light] .login-input{background:#fff;border-color:#0000001a}[data-theme=light] .login-input:focus{border-color:var(--accent-primary)}[data-theme=light] .gallery-item-overlay{background:linear-gradient(#0000 40%,#fffffff2 100%)}[data-theme=light] .gallery-item-name{color:var(--text-primary)}[data-theme=light] .lightbox-close,[data-theme=light] .lightbox-nav{color:#fff;background:#00000080}[data-theme=light] .lightbox-close:hover,[data-theme=light] .lightbox-nav:hover{background:#000000b3}[data-theme=light] .upload-zone:hover,[data-theme=light] .upload-zone.drag-over{background:#5b4cdb0a}[data-theme=light] .sidebar-link.active,[data-theme=light] .badge-admin{background:#5b4cdb1a}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:14px}body{background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6;overflow-x:hidden}a{color:var(--text-accent);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--accent-primary)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.app-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--glass-bg);-webkit-backdrop-filter:blur(24px);border-right:1px solid var(--glass-border);z-index:200;flex-direction:column;transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-brand{border-bottom:1px solid var(--glass-border);align-items:center;gap:12px;padding:20px;display:flex}.sidebar-brand-icon{background:#fff;border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;font-size:17px;display:flex;box-shadow:0 2px 8px #0000001a}.sidebar-brand-text{background:var(--accent-gradient);-webkit-text-fill-color:transparent;letter-spacing:-.3px;-webkit-background-clip:text;background-clip:text;font-size:15px;font-weight:700}.sidebar-upload-btn{margin:0 14px 4px}.sidebar-nav{scrollbar-width:thin;scrollbar-color:var(--border-hover)transparent;flex:1;padding:12px 10px;overflow-y:auto}.sidebar-section-title{text-transform:uppercase;letter-spacing:1.4px;color:var(--text-muted);padding:20px 12px 8px;font-size:10px;font-weight:700}.sidebar-link{border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:12px;width:100%;margin-bottom:2px;padding:9px 12px;font-size:13px;font-weight:500;transition:all .15s;display:flex;position:relative}.sidebar-link:hover{color:var(--text-primary);background:#ffffff0a}.sidebar-link.active{color:var(--accent-secondary);background:#6c5ce71f;font-weight:600}.sidebar-link.active:before{content:"";background:var(--accent-gradient);width:3px;box-shadow:var(--accent-glow);border-radius:0 3px 3px 0;position:absolute;top:6px;bottom:6px;left:0}.sidebar-link-icon{opacity:.8;flex-shrink:0;justify-content:center;align-items:center;width:22px;font-size:18px;display:flex}.sidebar-link.active .sidebar-link-icon{opacity:1}.sidebar-user{border-top:1px solid var(--glass-border);align-items:center;gap:10px;padding:14px 16px;display:flex;position:relative}.sidebar-user-avatar{background:var(--accent-gradient);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:13px;font-weight:600;display:flex;overflow:hidden;box-shadow:0 0 0 2px #6c5ce74d}.sidebar-user-avatar img{object-fit:cover;width:100%;height:100%}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{white-space:nowrap;text-overflow:ellipsis;letter-spacing:-.2px;font-size:13px;font-weight:600;overflow:hidden}.sidebar-user-role{color:var(--text-muted);margin-top:1px;font-size:11px}.sidebar-user-actions{align-items:center;gap:2px;display:flex}.sidebar-user-actions .btn-ghost{border-radius:var(--radius-sm);color:var(--text-muted);padding:6px;transition:all .15s}.sidebar-user-actions .btn-ghost:hover{color:var(--text-primary);background:#ffffff0f}.main-content{margin-left:var(--sidebar-width);flex:1;min-height:100vh}.sidebar-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:199;background:#00000080;animation:.25s fadeIn;display:none;position:fixed;inset:0}.mobile-bottom-nav{z-index:198;background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--glass-border);padding:6px 0 calc(6px + env(safe-area-inset-bottom));display:none;position:fixed;bottom:0;left:0;right:0}.mobile-bottom-nav-inner{justify-content:space-around;align-items:center;display:flex}.mobile-nav-item{color:var(--text-muted);cursor:pointer;background:0 0;border:none;flex-direction:column;align-items:center;gap:3px;min-width:56px;padding:6px 12px;font-size:10px;font-weight:500;text-decoration:none;transition:color .15s;display:flex}.mobile-nav-item.active{color:var(--accent-secondary)}.mobile-nav-item:hover{color:var(--text-primary)}.mobile-nav-fab{background:var(--accent-gradient);color:#fff;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;transition:transform .2s,box-shadow .2s;display:flex;position:relative;transform:translateY(-12px);box-shadow:0 4px 16px #6c5ce766}.mobile-nav-fab:hover{transform:translateY(-14px);box-shadow:0 6px 20px #6c5ce780}.mobile-nav-fab:active{transform:translateY(-10px)scale(.95)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.page-header{border-bottom:1px solid var(--border-default);background:var(--bg-secondary);z-index:50;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:24px 32px;position:sticky;top:0}.page-header-row{justify-content:space-between;align-items:center;gap:16px;display:flex}.page-title{letter-spacing:-.3px;font-size:22px;font-weight:700}.page-subtitle{color:var(--text-secondary);margin-top:4px;font-size:13px}.page-body{padding:24px 32px}.card{background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-lg);transition:all var(--transition-normal);padding:24px}.card:hover{border-color:var(--border-hover);box-shadow:var(--glass-shadow)}.card-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.card-title{font-size:16px;font-weight:600}.card-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;display:grid}.stat-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;margin-bottom:32px;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:20px;position:relative;overflow:hidden}.stat-card:before{content:"";background:var(--accent-gradient);opacity:.6;height:3px;position:absolute;top:0;left:0;right:0}.stat-card-icon{margin-bottom:12px;font-size:28px}.stat-card-value{letter-spacing:-.5px;background:var(--accent-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:28px;font-weight:800}.stat-card-label{color:var(--text-secondary);margin-top:4px;font-size:12px;font-weight:500}.dash-hero-stats{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px;display:grid}.dash-hero-card{background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-lg);align-items:center;gap:16px;padding:24px;transition:border-color .2s;display:flex;position:relative;overflow:hidden}.dash-hero-card:hover{border-color:var(--border-hover)}.dash-hero-card:before{content:"";background:var(--accent-gradient);opacity:.5;height:3px;position:absolute;top:0;left:0;right:0}.dash-hero-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;display:flex}.dash-hero-info{flex:1}.dash-hero-value{letter-spacing:-.5px;background:var(--accent-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:28px;font-weight:800;line-height:1.1}.dash-hero-label{color:var(--text-secondary);margin-top:4px;font-size:13px;font-weight:500}.dash-secondary-stats{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px;display:grid}.dash-stat-mini{background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-md);text-align:center;padding:16px;transition:border-color .2s}.dash-stat-mini:hover{border-color:var(--border-hover)}.dash-stat-mini-icon{color:var(--text-muted);justify-content:center;margin-bottom:8px;display:flex}.dash-stat-mini-value{color:var(--text-primary);letter-spacing:-.3px;font-size:22px;font-weight:700}.dash-stat-mini-label{color:var(--text-muted);margin-top:2px;font-size:11px;font-weight:500}.dash-projects-mobile{flex-direction:column;gap:8px;padding:12px 16px;display:none}.dash-project-mobile-card{background:var(--bg-elevated);border-radius:var(--radius-md);padding:14px 16px;text-decoration:none;transition:background .15s;display:block}.dash-project-mobile-card:hover{background:var(--bg-card-hover)}.dash-table-desktop{display:table}@media (max-width:768px){.dash-hero-stats{grid-template-columns:1fr}.dash-secondary-stats{grid-template-columns:repeat(2,1fr)}.dash-table-desktop{display:none}.dash-projects-mobile{display:flex}.dash-hero-card{padding:18px}.dash-hero-value{font-size:24px}}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:1px solid #0000;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-family:inherit;font-size:13px;font-weight:600;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent-gradient);color:#fff;box-shadow:var(--accent-glow);border:none}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 0 30px #6c5ce766}.btn-secondary{background:var(--bg-card);color:var(--text-primary);border-color:var(--border-default)}.btn-secondary:hover:not(:disabled){background:var(--bg-card-hover);border-color:var(--border-hover)}.btn-danger{background:var(--danger-bg);color:var(--danger);border-color:#ff6b6b33}.btn-danger:hover:not(:disabled){background:#ff6b6b33}.btn-ghost{color:var(--text-secondary);background:0 0;border:none;padding:8px 12px}.btn-ghost:hover{color:var(--text-primary);background:var(--bg-card)}.btn-sm{padding:6px 14px;font-size:12px}.btn-lg{padding:14px 28px;font-size:15px}.btn-icon{width:36px;height:36px;padding:8px}.form-group{margin-bottom:20px}.form-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:12px;font-weight:600;display:block}.form-input,.form-select,.form-textarea{background:var(--bg-input);border:1px solid var(--border-default);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);transition:border-color var(--transition-fast);padding:10px 14px;font-family:inherit;font-size:14px}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent-primary);outline:none;box-shadow:0 0 0 3px #6c5ce726}.form-input::placeholder{color:var(--text-muted)}.form-textarea{resize:vertical;min-height:80px}.form-select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%239898b0' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}.badge{letter-spacing:.3px;border-radius:99px;align-items:center;gap:4px;padding:3px 10px;font-size:11px;font-weight:600;display:inline-flex}.badge-published{background:var(--success-bg);color:var(--success)}.badge-draft{background:var(--warning-bg);color:var(--warning)}.badge-archived{color:var(--text-muted);background:#ffffff0d}.badge-admin{color:var(--accent-secondary);background:#6c5ce726}.badge-lead{background:var(--info-bg);color:var(--info)}.badge-member{color:var(--text-secondary);background:#ffffff0d}.badge-source{background:var(--warning-bg);color:var(--warning)}.badge-output{background:var(--success-bg);color:var(--success)}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;animation:fadeIn var(--transition-fast);background:#0009;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-xl);width:100%;max-width:520px;max-height:90vh;animation:slideUp var(--transition-normal);overflow-y:auto}.modal-header{border-bottom:1px solid var(--border-default);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-title{font-size:16px;font-weight:700}.modal-close{color:var(--text-muted);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;padding:4px;font-size:20px}.modal-close:hover{color:var(--text-primary)}.modal-body{padding:24px}.modal-footer{border-top:1px solid var(--border-default);justify-content:flex-end;gap:8px;padding:16px 24px;display:flex}.upload-zone{border:2px dashed var(--border-hover);border-radius:var(--radius-lg);text-align:center;cursor:pointer;transition:all var(--transition-normal);padding:48px 24px;position:relative}.upload-zone:hover,.upload-zone.drag-over{border-color:var(--accent-primary);background:#6c5ce70d}.upload-zone-icon{opacity:.5;margin-bottom:12px;font-size:48px}.upload-zone-text{color:var(--text-secondary);margin-bottom:4px;font-size:14px}.upload-zone-hint{color:var(--text-muted);font-size:12px}.upload-zone input[type=file]{opacity:0;cursor:pointer;position:absolute;inset:0}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;display:grid}.gallery-item{aspect-ratio:1;border-radius:var(--radius-md);background:var(--bg-card);border:1px solid var(--border-default);cursor:pointer;transition:all var(--transition-normal);position:relative;overflow:hidden}.gallery-item:hover{box-shadow:var(--glass-shadow);border-color:var(--accent-primary);transform:translateY(-2px)}.gallery-item-image{object-fit:cover;width:100%;height:100%}.gallery-item-overlay{opacity:0;transition:opacity var(--transition-fast);background:linear-gradient(#0000 40%,#000c 100%);flex-direction:column;justify-content:flex-end;padding:12px;display:flex;position:absolute;inset:0}.gallery-item:hover .gallery-item-overlay{opacity:1}.gallery-item-name{white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:600;overflow:hidden}.gallery-item-meta{color:var(--text-muted);margin-top:2px;font-size:10px}.gallery-item-placeholder{opacity:.3;justify-content:center;align-items:center;font-size:48px;display:flex}.data-table{border-collapse:collapse;width:100%}.data-table th{text-align:left;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);border-bottom:1px solid var(--border-default);padding:12px 16px;font-size:11px;font-weight:600}.data-table td{border-bottom:1px solid var(--border-default);padding:14px 16px;font-size:13px}.data-table tr:hover td{background:#ffffff05}.toast-container{z-index:9999;flex-direction:column;gap:8px;display:flex;position:fixed;top:20px;right:20px}.toast{background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-md);animation:slideInRight var(--transition-normal);min-width:280px;box-shadow:var(--glass-shadow);align-items:center;gap:10px;padding:14px 20px;font-size:13px;display:flex}.toast-success{border-left:3px solid var(--success)}.toast-error{border-left:3px solid var(--danger)}.spinner{border:2px solid var(--border-default);border-top-color:var(--accent-primary);border-radius:50%;width:20px;height:20px;animation:.6s linear infinite spin}.page-loading{min-height:300px;color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex}.empty-state{text-align:center;padding:60px 24px}.empty-state-icon{opacity:.4;margin-bottom:16px;font-size:56px}.empty-state-text{color:var(--text-secondary);margin-bottom:8px;font-size:15px}.empty-state-hint{color:var(--text-muted);margin-bottom:24px;font-size:13px}.settings-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px;display:grid}.settings-section{background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-lg);transition:border-color .2s;overflow:hidden}.settings-section:hover{border-color:var(--border-hover)}.settings-section-header{border-bottom:1px solid var(--border-default);align-items:center;gap:12px;padding:18px 20px;display:flex}.settings-section-icon{border-radius:var(--radius-sm);width:36px;height:36px;color:var(--accent-secondary);background:#6c5ce71f;flex-shrink:0;justify-content:center;align-items:center;display:flex}.settings-section-title{color:var(--text-primary);font-size:14px;font-weight:600}.settings-section-desc{color:var(--text-muted);margin-top:2px;font-size:11px}.settings-section-body{padding:4px 0}.settings-item{justify-content:space-between;align-items:center;gap:12px;padding:12px 20px;display:flex}.settings-item+.settings-item{border-top:1px solid var(--border-default)}.settings-item-label{color:var(--text-secondary);align-items:center;gap:8px;font-size:13px;display:flex}.settings-item-value{color:var(--text-primary);text-align:right;font-size:13px;font-weight:600}@media (max-width:768px){.settings-grid{grid-template-columns:1fr}}.login-page{background:var(--bg-primary);min-height:100vh;display:flex}.login-branding{background:var(--bg-secondary);flex:1;justify-content:center;align-items:center;padding:48px;display:flex;position:relative;overflow:hidden}.login-branding-content{z-index:2;max-width:380px;position:relative}.login-branding-logo{background:#fff;border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;margin-bottom:24px;display:flex;box-shadow:0 4px 16px #0000001a}.login-branding-title{letter-spacing:-.5px;background:var(--accent-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:12px;font-size:28px;font-weight:800}.login-branding-desc{color:var(--text-secondary);margin-bottom:40px;font-size:15px;line-height:1.6}.login-features{flex-direction:column;gap:20px;display:flex}.login-feature{align-items:flex-start;gap:14px;display:flex}.login-feature-icon{border-radius:var(--radius-sm);width:36px;height:36px;color:var(--accent-secondary);background:#6c5ce726;flex-shrink:0;justify-content:center;align-items:center;display:flex}.login-feature-title{color:var(--text-primary);margin-bottom:3px;font-size:13px;font-weight:600}.login-feature-desc{color:var(--text-muted);font-size:12px;line-height:1.4}.login-branding-orb{pointer-events:none;border-radius:50%;position:absolute}.login-branding-orb-1{background:radial-gradient(circle,#6c5ce71f 0%,#0000 70%);width:500px;height:500px;top:-180px;right:-100px}.login-branding-orb-2{background:radial-gradient(circle,#a29bfe14 0%,#0000 70%);width:350px;height:350px;bottom:-80px;left:-80px}.login-form-panel{flex:1;justify-content:center;align-items:center;padding:32px;display:flex;position:relative}.login-card{text-align:center;width:100%;max-width:380px}.login-logo{background:#fff;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 20px;display:flex;box-shadow:0 4px 16px #0000001a}.login-title{letter-spacing:-.3px;color:var(--text-primary);margin-bottom:6px;font-size:22px;font-weight:800}.login-subtitle{color:var(--text-secondary);margin-bottom:32px;font-size:14px}.login-form{text-align:left;flex-direction:column;gap:16px;display:flex}.login-field{position:relative}.login-input{background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-md);width:100%;color:var(--text-primary);box-sizing:border-box;outline:none;padding:16px 16px 8px;font-family:inherit;font-size:14px;transition:border-color .2s,box-shadow .2s}.login-input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #6c5ce726}.login-label{color:var(--text-muted);pointer-events:none;background:0 0;font-size:14px;transition:all .2s;position:absolute;top:50%;left:16px;transform:translateY(-50%)}.login-input:focus+.login-label,.login-input:not(:placeholder-shown)+.login-label{color:var(--accent-secondary);letter-spacing:.5px;font-size:10px;font-weight:600;top:8px;transform:translateY(0)}.login-eye-toggle{color:var(--text-muted);cursor:pointer;background:0 0;border:none;align-items:center;padding:4px;transition:color .15s;display:flex;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.login-eye-toggle:hover{color:var(--text-primary)}.login-error{color:var(--danger);text-align:center;background:var(--danger-bg);border-radius:var(--radius-sm);border:1px solid #ff6b6b33;padding:8px 12px;font-size:13px}.login-submit-btn{background:var(--accent-gradient);color:#fff;border-radius:var(--radius-md);cursor:pointer;border:none;justify-content:center;align-items:center;gap:10px;width:100%;margin-top:4px;padding:14px 24px;font-family:inherit;font-size:15px;font-weight:600;transition:all .2s;display:flex;box-shadow:0 4px 15px #6c5ce74d}.login-submit-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 25px #6c5ce766}.login-submit-btn:active:not(:disabled){transform:translateY(0)}.login-submit-btn:disabled{opacity:.5;cursor:not-allowed}.login-footer-text{color:var(--text-muted);text-align:center;margin-top:28px;font-size:11px}@media (max-width:768px){.login-page{flex-direction:column}.login-branding{display:none}.login-form-panel{min-height:100vh}.login-card{padding:24px 0}}.share-page{background:var(--bg-primary);min-height:100vh}.share-header{text-align:center;border-bottom:1px solid var(--border-default);background:var(--bg-secondary);padding:32px}.share-project-name{margin-bottom:8px;font-size:28px;font-weight:800}.share-meta{color:var(--text-secondary);justify-content:center;align-items:center;gap:16px;font-size:13px;display:flex}.share-body{max-width:1200px;margin:0 auto;padding:32px}.share-post{margin-bottom:40px}.share-post-title{border-bottom:1px solid var(--border-default);margin-bottom:16px;padding-bottom:8px;font-size:18px;font-weight:700}.share-password-gate{text-align:center;max-width:400px;margin:100px auto}.lightbox{z-index:2000;animation:fadeIn var(--transition-fast);background:#000000f2;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.lightbox-image{object-fit:contain;border-radius:var(--radius-sm);max-width:90vw;max-height:90vh}.lightbox-close{color:#fff;cursor:pointer;width:40px;height:40px;transition:background var(--transition-fast);background:#ffffff1a;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:20px;display:flex;position:absolute;top:20px;right:20px}.lightbox-close:hover{background:#fff3}.lightbox-nav{color:#fff;cursor:pointer;width:48px;height:48px;transition:background var(--transition-fast);background:#ffffff1a;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:24px;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.lightbox-nav:hover{background:#fff3}.lightbox-prev{left:20px}.lightbox-next{right:20px}.breadcrumb{color:var(--text-muted);align-items:center;gap:8px;margin-bottom:16px;font-size:13px;display:flex}.breadcrumb-item{color:var(--text-secondary)}.breadcrumb-item:hover{color:var(--text-accent)}.breadcrumb-separator{color:var(--text-muted)}.breadcrumb-current{color:var(--text-primary);font-weight:500}.share-link-box{background:var(--bg-input);border:1px solid var(--border-default);border-radius:var(--radius-md);align-items:center;gap:12px;padding:12px 16px;display:flex}.share-link-url{color:var(--text-accent);white-space:nowrap;text-overflow:ellipsis;flex:1;font-family:SF Mono,Fira Code,monospace;font-size:13px;overflow:hidden}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(100px)}to{opacity:1;transform:translate(0)}}@keyframes spin{to{transform:rotate(360deg)}}.upload-panel-spinner{border:2px solid var(--accent);border-top-color:#0000;border-radius:50%;width:16px;height:16px;animation:.8s linear infinite spin}@keyframes upload-panel-streakPulse{0%{transform:scale(1)}50%{transform:scale(1.25)}to{transform:scale(1)}}@media (max-width:1024px){:root{--sidebar-width:220px}}@media (max-width:768px){html,body{width:100%;margin:0;padding:0;position:relative;max-width:100vw!important;overflow-x:hidden!important}.app-layout{width:100%;position:relative;max-width:100vw!important;display:block!important;overflow-x:hidden!important}.sidebar{width:var(--sidebar-width)!important;transform:translate(-100%)!important}.sidebar.open{transform:translate(0)!important;box-shadow:10px 0 30px #0003!important}.sidebar-overlay.visible,.mobile-bottom-nav{display:block}.main-content{padding-bottom:calc(60px + env(safe-area-inset-bottom));box-sizing:border-box;width:100%;max-width:100vw;margin-left:0;overflow-x:hidden}.page-header{padding:16px 20px}.page-body{box-sizing:border-box;width:100%;max-width:100vw;padding:16px 20px;overflow-x:hidden}.stat-grid{grid-template-columns:repeat(2,1fr)}.card-grid{grid-template-columns:1fr}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.login-card{padding:32px 24px}.page-title{font-size:18px}.page-subtitle{font-size:12px}}.gallery-item-reactions{opacity:0;transition:opacity .2s}.gallery-item:hover .gallery-item-reactions{opacity:1}.gallery-item-reactions:has(button span+span){opacity:1}.gallery-reaction-add:hover .reaction-picker{gap:2px;display:flex!important}.gallery-reaction-add:hover{color:#fff!important;background:#0009!important}.table{border-collapse:separate;border-spacing:0;background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-lg);overflow:hidden}.table th{background:var(--bg-elevated);text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);text-align:left;white-space:nowrap;border-bottom:2px solid var(--border-default);z-index:1;padding:10px 12px;font-size:11px;font-weight:600;position:sticky;top:0}.table td{border-bottom:1px solid var(--border-default);vertical-align:middle;padding:10px 12px}.table tbody tr:hover{background:#6366f108}.table tbody tr:last-child td{border-bottom:none}@media (max-width:768px){.table th,.table td{padding:8px;font-size:11px}}.cv-stats-grid{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px;display:grid}.cv-stat-card{background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-lg);align-items:center;gap:12px;padding:14px 16px;display:flex}.cv-stat-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.cv-stat-value{font-size:20px;font-weight:700;line-height:1.2}.cv-stat-label{color:var(--text-muted);font-size:11px;font-weight:500}.cv-search-bar{align-items:center;gap:8px;margin-bottom:16px;display:flex}.cv-id-badge{color:var(--accent);white-space:nowrap;background:#6366f114;border-radius:6px;padding:3px 10px;font-size:12px;font-weight:700}.cv-badge{border-radius:4px;align-items:center;gap:2px;padding:2px 6px;font-size:10px;font-weight:600;display:inline-flex}.cv-badge-image{color:#ec4899;background:#ec48991a}.cv-badge-source{color:#6c5ce7;background:#6c5ce71a}.cv-badge-review{color:#10b981;background:#10b9811a}.cv-badge-package{color:#f59e0b;background:#f59e0b1a}.cv-link-btn{cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;padding:4px;text-decoration:none;transition:all .15s;display:inline-flex}.cv-link-btn:hover{background:var(--bg-elevated)}.cv-table-desktop{display:block;overflow-x:auto}.cv-cards-mobile{display:none}.cv-card{background:var(--bg-card);border:1px solid var(--border-default);border-radius:var(--radius-lg);margin-bottom:10px;padding:14px 16px}.cv-card-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.cv-card-footer{border-top:1px solid var(--border-default);justify-content:space-between;align-items:center;padding-top:8px;display:flex}@media (max-width:1024px){.cv-stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.cv-stats-grid{grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:14px}.cv-stat-card{gap:8px;padding:10px 12px}.cv-stat-icon{border-radius:8px;width:30px;height:30px}.cv-stat-value{font-size:16px}.cv-search-bar{z-index:10;background:var(--bg-primary);margin-bottom:12px;padding:8px 0;position:sticky;top:56px}.cv-table-desktop{display:none}.cv-cards-mobile{display:block}}.skeleton{background:linear-gradient(90deg,var(--bg-elevated)25%,#ffffff14 50%,var(--bg-elevated)75%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.5s ease-in-out infinite shimmer}.skeleton-text{height:14px;margin-bottom:8px}.skeleton-text-sm{width:60%;height:10px;margin-bottom:6px}.skeleton-card{border-radius:var(--radius-lg);height:120px}.skeleton-avatar{border-radius:50%;width:36px;height:36px}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.fade-in{animation:.3s ease-out fadeIn}.page-body{animation:.25s ease-out fadeIn}.card{transition:transform .2s,box-shadow .2s,border-color .2s}.card:hover{transform:translateY(-2px);box-shadow:0 8px 25px #00000014}.btn{transition:all .15s}.btn:active{transform:scale(.97)}.btn-primary:hover{box-shadow:0 4px 15px #6366f14d}@keyframes pulse-badge{0%,to{box-shadow:0 0 #22c55e66}50%{box-shadow:0 0 0 4px #22c55e00}}.badge-pulse{animation:2s ease-in-out 3 pulse-badge}.empty-state-icon{background:linear-gradient(135deg,#6366f11a,#ec489914);border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin:0 auto 16px;font-size:32px;display:flex}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.toast-enter{animation:.3s cubic-bezier(.4,0,.2,1) slideIn}.nav-link{transition:all .15s}.nav-link:hover{transform:translate(2px)}.gallery-item img{transition:transform .3s}.gallery-item:hover img{transform:scale(1.03)}.stat-card-value{transition:all .3s}.form-input:focus,.form-textarea:focus,.form-select:focus{transition:box-shadow .2s,border-color .2s;box-shadow:0 0 0 3px #6366f126}@media (max-width:768px){.card:active{transform:scale(.98)}.btn:active{transform:scale(.95)}}
