.layout-container{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;display:flex;flex-direction:column;transition:margin-left .3s ease}.main-content.with-sidebar{margin-left:280px;transition:margin-left .3s ease}.main-content.sidebar-collapsed{margin-left:80px}.sidebar{position:fixed;left:0;top:0;height:100vh;width:280px;background:linear-gradient(180deg,#1e293b,#0f172a);border-right:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;z-index:1000;box-shadow:4px 0 20px #0000004d;transition:width .3s ease}.sidebar.collapsed{width:80px}.sidebar-header{padding:1.5rem;border-bottom:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:space-between;gap:.5rem}.sidebar-header .logo-link{display:flex;align-items:center;text-decoration:none;flex:1;min-width:0}.sidebar-header .logo-text{font-size:1.5rem;font-weight:800;background:linear-gradient(135deg,#10b981,#06b6d4,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-toggle-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:.5rem;color:#cbd5e1;cursor:pointer;transition:all .3s ease;flex-shrink:0}.sidebar-toggle-btn:hover{background:#ffffff26;color:#fff;border-color:#ffffff4d}.sidebar.collapsed .sidebar-toggle-btn{margin:0 auto}.sidebar.collapsed .logo-link{display:none}.sidebar-nav{flex:1;padding:1rem 0;overflow-y:auto;overflow-x:hidden}.sidebar-nav::-webkit-scrollbar{width:6px}.sidebar-nav::-webkit-scrollbar-track{background:#ffffff0d}.sidebar-nav::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.sidebar-item{display:flex;align-items:center;gap:.75rem;padding:.875rem 1.5rem;color:#cbd5e1;text-decoration:none;transition:all .3s ease;border-left:3px solid transparent;cursor:pointer;background:none;border-top:none;border-right:none;border-bottom:none;width:100%;text-align:left;font-size:.95rem;font-weight:500}.sidebar-item:hover{background:#ffffff0d;color:#fff;border-left-color:#06b6d4}.sidebar-item.active{background:#06b6d426;color:#06b6d4;border-left-color:#06b6d4}.sidebar-icon{font-size:1.25rem;width:24px;text-align:center}.sidebar-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar.collapsed .sidebar-label{display:none}.sidebar.collapsed .sidebar-item{justify-content:center;padding:.875rem}.sidebar.collapsed .admin-arrow{display:none}.admin-menu-section{margin-top:.5rem}.admin-toggle{position:relative}.admin-arrow{font-size:.75rem;transition:transform .3s ease;margin-left:auto}.admin-arrow.open{transform:rotate(180deg)}.admin-submenu{background:#0003;border-left:2px solid rgba(6,182,212,.3);margin-left:1.5rem;margin-top:.25rem;margin-bottom:.5rem}.submenu-item{padding-left:2.5rem;font-size:.875rem}.submenu-item .sidebar-icon{font-size:1rem}.sidebar-footer{padding:1.5rem;border-top:1px solid rgba(255,255,255,.1);background:#0003}.user-info{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid rgba(255,255,255,.1)}.user-info-collapsed{display:flex;align-items:center;justify-content:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar:not(.collapsed) .user-info-collapsed{display:none}.sidebar.collapsed .user-info{display:none}.user-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#10b981,#06b6d4);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1rem}.user-details{flex:1;min-width:0}.user-email{display:block;color:#cbd5e1;font-size:.875rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.logout-btn-sidebar{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:none;border-radius:.5rem;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .3s ease;justify-content:center}.logout-btn-sidebar:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);transform:translateY(-2px);box-shadow:0 4px 12px #ef444466}.logout-btn-sidebar .sidebar-icon{font-size:1rem}.sidebar.collapsed .logout-btn-sidebar{padding:.75rem}.nav-header{position:relative;animation:slideDown .5s ease-out}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}@media (max-width: 1024px){.main-content.with-sidebar{margin-left:0}.sidebar{transform:translate(-100%);transition:transform .3s ease;box-shadow:none}.sidebar.open{transform:translate(0);box-shadow:4px 0 20px #00000080}}@media (max-width: 640px){.sidebar{width:260px}.sidebar-item{padding:.75rem 1.25rem;font-size:.9rem}.sidebar-icon{font-size:1.1rem}}.logo-link{display:flex;align-items:center;gap:.75rem;text-decoration:none;font-weight:800;font-size:1.5rem;background:linear-gradient(135deg,#10b981,#06b6d4,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;transition:all .3s ease;position:relative}.logo-link:hover{transform:scale(1.05)}.logo-text{font-size:1.5rem;background:linear-gradient(135deg,#10b981,#06b6d4,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;position:relative}.nav-link{position:relative;text-decoration:none;color:#374151;font-weight:600;font-size:.95rem;padding:.5rem 0;transition:all .3s cubic-bezier(.4,0,.2,1)}.nav-link-text{position:relative;z-index:1;transition:color .3s ease}.nav-link-underline{position:absolute;bottom:0;left:0;width:0;height:2px;background:linear-gradient(90deg,#10b981,#06b6d4);transition:width .3s cubic-bezier(.4,0,.2,1)}.nav-link:hover .nav-link-text{color:#06b6d4}.nav-link:hover .nav-link-underline{width:100%}.user-badge{display:none;padding:.5rem 1rem;background:linear-gradient(135deg,#10b9811a,#06b6d41a);border-radius:1rem;border:1px solid rgba(6,182,212,.2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.user-email{font-size:.875rem;color:#374151;font-weight:500}@media (min-width: 640px){.user-badge{display:block}}.signup-btn{position:relative;padding:.625rem 1.5rem;text-decoration:none;border-radius:.75rem;overflow:hidden;font-weight:600;font-size:.95rem;transition:all .3s cubic-bezier(.4,0,.2,1);display:inline-flex;align-items:center;gap:.5rem}.signup-btn-bg{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#10b981,#06b6d4,#3b82f6);background-size:200% 200%;animation:gradientShift 3s ease infinite;transition:transform .3s ease}.signup-btn-text{position:relative;z-index:1;color:#fff}.signup-btn:hover{transform:translateY(-2px);box-shadow:0 10px 25px #06b6d466}.signup-btn:hover .signup-btn-bg{transform:scale(1.05)}.logout-btn{position:relative;padding:.625rem 1.25rem;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:none;border-radius:.75rem;font-weight:600;font-size:.95rem;cursor:pointer;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1);display:inline-flex;align-items:center;gap:.5rem}.logout-btn:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#dc2626,#b91c1c);opacity:0;transition:opacity .3s ease}.logout-btn span{position:relative;z-index:1}.logout-btn:hover{transform:translateY(-2px);box-shadow:0 10px 25px #ef444466}.logout-btn:hover:before{opacity:1}.footer-modern{background:linear-gradient(135deg,#1e293b,#334155);border-top:1px solid rgba(255,255,255,.1);padding:2rem 0;position:relative;overflow:hidden}.footer-modern:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(6,182,212,.5),transparent);animation:shimmer 3s ease-in-out infinite}@keyframes shimmer{0%,to{transform:translate(-100%)}50%{transform:translate(100%)}}.footer-content{display:flex;flex-direction:column;gap:1rem;align-items:center;justify-content:space-between}@media (min-width: 640px){.footer-content{flex-direction:row}}.footer-text{display:flex;align-items:center;gap:.5rem;color:#94a3b8;font-size:.875rem}.footer-links{display:flex;gap:1.5rem;flex-wrap:wrap;justify-content:center}.footer-link{color:#94a3b8;text-decoration:none;font-size:.875rem;transition:all .3s ease;position:relative}.footer-link:after{content:"";position:absolute;bottom:-4px;left:0;width:0;height:2px;background:linear-gradient(90deg,#10b981,#06b6d4);transition:width .3s ease}.footer-link:hover{color:#06b6d4}.footer-link:hover:after{width:100%}@media (max-width: 640px){.logo-text{font-size:1.25rem}}.admin-layout{min-height:100vh;background:#f5f5f5;display:flex;flex-direction:column}.admin-app-bar{position:fixed;top:0;left:0;right:0;height:64px;background:#1976d2;color:#fff;box-shadow:0 2px 4px #0000001a,0 4px 8px #0000001a;z-index:1200;display:flex;align-items:center}.admin-app-bar-content{width:100%;max-width:100%;padding:0 16px;display:flex;align-items:center;justify-content:space-between}.admin-app-bar-left{display:flex;align-items:center;gap:16px}.admin-menu-button{display:none;background:none;border:none;color:#fff;cursor:pointer;padding:8px;border-radius:4px;transition:background-color .2s}.admin-menu-button:hover{background-color:#ffffff1a}.admin-logo{display:flex;align-items:center;gap:12px;text-decoration:none;color:#fff;font-weight:500;font-size:20px}.admin-logo-icon{width:32px;height:32px}.admin-logo-text{font-weight:500}.admin-app-bar-right{display:flex;align-items:center;gap:16px}.admin-user-menu{display:flex;align-items:center;gap:12px;padding:8px 12px;border-radius:24px;transition:background-color .2s}.admin-user-menu:hover{background-color:#ffffff1a}.admin-user-avatar{width:40px;height:40px;border-radius:50%;background:#42a5f5;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:16px}.admin-user-info{display:flex;flex-direction:column}.admin-user-name{font-size:14px;font-weight:500;line-height:1.2}.admin-user-role{font-size:12px;opacity:.8;line-height:1.2}.admin-icon-button{background:none;border:none;color:#fff;cursor:pointer;padding:8px;border-radius:4px;transition:background-color .2s;display:flex;align-items:center;justify-content:center}.admin-icon-button:hover{background-color:#ffffff1a}.admin-icon{width:24px;height:24px}.admin-layout-body{display:flex;margin-top:64px;min-height:calc(100vh - 64px)}.admin-sidebar{width:256px;background:#fff;box-shadow:2px 0 4px #0000000d;position:fixed;left:0;top:64px;bottom:0;overflow-y:auto;z-index:1100;transition:transform .3s ease}.admin-nav{padding:16px 0}.admin-nav-item{display:flex;align-items:center;gap:16px;padding:12px 24px;color:#424242;text-decoration:none;transition:all .2s;position:relative}.admin-nav-item:hover{background-color:#f5f5f5}.admin-nav-item.active{background-color:#e3f2fd;color:#1976d2;font-weight:500}.admin-nav-item.active:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:#1976d2}.admin-nav-icon{width:24px;height:24px;fill:currentColor}.admin-nav-label{font-size:14px}.admin-main-content{flex:1;margin-left:256px;padding:24px;background:#f5f5f5;min-height:calc(100vh - 64px)}@media (max-width: 960px){.admin-menu-button{display:flex}.admin-user-info{display:none}.admin-sidebar{transform:translate(-100%)}.admin-sidebar.mobile-open{transform:translate(0);box-shadow:4px 0 8px #00000026}.admin-main-content{margin-left:0;padding:16px}.admin-mobile-overlay{position:fixed;top:64px;left:0;right:0;bottom:0;background:#00000080;z-index:1000}}.admin-card{background:#fff;border-radius:4px;box-shadow:0 2px 4px #0000001a,0 4px 8px #0000001a;padding:24px;margin-bottom:24px;transition:box-shadow .2s}.admin-card:hover{box-shadow:0 4px 8px #0000001f,0 8px 16px #0000001f}.admin-button{background:#1976d2;color:#fff;border:none;border-radius:4px;padding:10px 24px;font-size:14px;font-weight:500;text-transform:uppercase;cursor:pointer;transition:background-color .2s,box-shadow .2s;box-shadow:0 2px 4px #0003}.admin-button:hover{background:#1565c0;box-shadow:0 4px 8px #0003}.admin-button:active{box-shadow:0 1px 2px #0003}.admin-button.secondary{background:#fff;color:#1976d2;border:1px solid #1976d2}.admin-button.secondary:hover{background:#f5f5f5}.admin-input{width:100%;padding:12px 16px;border:1px solid #e0e0e0;border-radius:4px;font-size:14px;transition:border-color .2s;background:#fff}.admin-input:focus{outline:none;border-color:#1976d2;box-shadow:0 0 0 2px #1976d21a}.admin-title{font-size:24px;font-weight:500;color:#212121;margin:0 0 8px}.admin-subtitle{font-size:14px;color:#757575;margin:0 0 24px}.admin-sidebar::-webkit-scrollbar{width:8px}.admin-sidebar::-webkit-scrollbar-track{background:#f5f5f5}.admin-sidebar::-webkit-scrollbar-thumb{background:#bdbdbd;border-radius:4px}.admin-sidebar::-webkit-scrollbar-thumb:hover{background:#9e9e9e}.admin-page{max-width:1200px;margin:0 auto}.admin-page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;flex-wrap:wrap;gap:16px}.admin-page-actions{display:flex;gap:12px}.admin-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px}.admin-loading-spinner{width:48px;height:48px;border:4px solid #e0e0e0;border-top-color:#1976d2;border-radius:50%;animation:spin 1s linear infinite}.admin-alert{padding:16px;border-radius:4px;margin-bottom:24px;display:flex;align-items:center;gap:12px}.admin-alert.success{background:#e8f5e9;color:#2e7d32;border:1px solid #4caf50}.admin-alert.error{background:#ffebee;color:#c62828;border:1px solid #ef5350}.admin-search-filter{display:flex;gap:16px;margin-bottom:24px;flex-wrap:wrap}.admin-search-input{flex:1;min-width:200px;position:relative}.admin-search-input input{padding-left:40px}.admin-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#757575;width:20px;height:20px}.admin-filter-buttons{display:flex;gap:8px}.admin-filter-button{padding:10px 16px;border:1px solid #e0e0e0;background:#fff;color:#424242;border-radius:4px;cursor:pointer;transition:all .2s;font-size:14px;font-weight:500}.admin-filter-button:hover{background:#f5f5f5}.admin-filter-button.active{background:#1976d2;color:#fff;border-color:#1976d2}.photo-layout{min-height:100vh;background:#f5f5f5;display:flex;flex-direction:column}.photo-app-bar{position:fixed;top:0;left:0;right:0;height:64px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 2px 4px #0000001a,0 4px 8px #0000001a;z-index:1200;display:flex;align-items:center}.photo-app-bar-content{width:100%;max-width:100%;padding:0 16px;display:flex;align-items:center;justify-content:space-between}.photo-app-bar-left{display:flex;align-items:center;gap:16px}.photo-logo{display:flex;align-items:center;gap:12px;text-decoration:none;color:#fff;font-weight:500;font-size:20px}.photo-logo-icon{width:32px;height:32px}.photo-logo-text{font-weight:500}.photo-back-button{background:#ffffff1a;border:none;color:#fff;cursor:pointer;padding:8px;border-radius:4px;transition:background-color .2s;display:flex;align-items:center;justify-content:center}.photo-back-button:hover{background-color:#fff3}.photo-app-bar-right{display:flex;align-items:center;gap:16px}.photo-user-menu{display:flex;align-items:center;gap:12px;padding:8px 12px;border-radius:24px;transition:background-color .2s}.photo-user-menu:hover{background-color:#ffffff1a}.photo-user-avatar{width:40px;height:40px;border-radius:50%;background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:16px;border:2px solid rgba(255,255,255,.3)}.photo-user-info{display:flex;flex-direction:column}.photo-user-name{font-size:14px;font-weight:500;line-height:1.2}.photo-user-role{font-size:12px;opacity:.9;line-height:1.2}.photo-icon-button{background:none;border:none;color:#fff;cursor:pointer;padding:8px;border-radius:4px;transition:background-color .2s;display:flex;align-items:center;justify-content:center}.photo-icon-button:hover{background-color:#ffffff1a}.photo-icon{width:24px;height:24px}.photo-main-content{flex:1;margin-top:64px;min-height:calc(100vh - 64px);background:#f5f5f5}@media (max-width: 768px){.photo-user-info{display:none}.photo-logo-text{font-size:18px}}.home-gallery-page{min-height:100vh;padding:2rem 1rem;background:linear-gradient(to bottom,#0f172a,#1e293b,#0f172a)}.home-loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:80vh;gap:1.5rem}.home-loading-text{color:#e2e8f0;font-size:1.125rem}.loading-spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.1);border-top-color:#06b6d4;border-radius:50%;animation:spin 1s linear infinite}.home-gallery-header{max-width:1400px;margin:0 auto 3rem;text-align:center}.home-gallery-title{font-size:3rem;font-weight:700;background:linear-gradient(to right,#10b981,#06b6d4,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.5rem}.home-gallery-subtitle{color:#94a3b8;font-size:1.125rem}.home-masonry-gallery{max-width:1400px;margin:0 auto;-moz-columns:4;columns:4;-moz-column-gap:1.5rem;column-gap:1.5rem;padding:0 1rem}@media (max-width: 1200px){.home-masonry-gallery{-moz-columns:3;columns:3}}@media (max-width: 768px){.home-masonry-gallery{-moz-columns:2;columns:2;-moz-column-gap:1rem;column-gap:1rem}}@media (max-width: 480px){.home-masonry-gallery{-moz-columns:1;columns:1}}.home-masonry-item{-moz-column-break-inside:avoid;break-inside:avoid;margin-bottom:1.5rem;border-radius:1rem;overflow:hidden;background:#ffffff0d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);animation:fadeInUp .6s ease-out both;position:relative}.home-masonry-item:hover{transform:translateY(-8px) scale(1.02);border-color:#06b6d480;box-shadow:0 20px 50px #0000004d,0 0 30px #06b6d433}.home-masonry-image{width:100%;height:auto;display:block;transition:transform .6s cubic-bezier(.4,0,.2,1)}.home-masonry-item:hover .home-masonry-image{transform:scale(1.1)}.home-masonry-placeholder{width:100%;min-height:200px;display:flex;align-items:center;justify-content:center;color:#ffffff80;font-size:.9rem}.home-masonry-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.8),transparent);padding:1rem;opacity:0;transition:opacity .4s ease}.home-masonry-item:hover .home-masonry-overlay{opacity:1}.home-masonry-style{color:#fff;font-size:.875rem;font-weight:600;text-shadow:0 2px 4px rgba(0,0,0,.5)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.home-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;padding:2rem}.home-empty-icon{width:80px;height:80px;color:#ffffff4d;margin-bottom:1.5rem}.home-empty-title{font-size:1.5rem;font-weight:700;color:#e2e8f0;margin-bottom:.5rem}.home-empty-text{color:#94a3b8;font-size:1rem}.home-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000e6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem;animation:fadeIn .3s ease-out}.home-modal-content{position:relative;max-width:95vw;max-height:95vh;background:#1e293bf2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:1.5rem;border:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;animation:modalSlideIn .3s ease-out;overflow:hidden}.home-modal-close{position:absolute;top:1rem;right:1rem;width:40px;height:40px;border-radius:50%;background:#00000080;border:1px solid rgba(255,255,255,.2);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;transition:all .3s ease}.home-modal-close:hover{background:#000000b3;transform:rotate(90deg)}.home-modal-close svg{width:24px;height:24px}.home-modal-image-container{position:relative;flex:1;display:flex;align-items:center;justify-content:center;overflow:auto;min-height:400px;max-height:70vh;background:#0000004d;padding:2rem}.home-modal-loading{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center}.home-modal-image{max-width:100%;max-height:100%;-o-object-fit:contain;object-fit:contain;transition:transform .3s ease;cursor:grab}.home-modal-image:active{cursor:grabbing}.home-modal-info{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-top:1px solid rgba(255,255,255,.1);gap:1rem}.home-modal-info-left{display:flex;align-items:center;gap:1rem;flex:1;min-width:0}.home-modal-style-badge{padding:.5rem 1rem;background:linear-gradient(135deg,#10b981,#06b6d4);border-radius:.5rem;color:#fff;font-size:.875rem;font-weight:600;white-space:nowrap}.home-modal-filename{color:#e2e8f0;font-size:.875rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.home-modal-info-right{color:#94a3b8;font-size:.875rem;white-space:nowrap}.home-modal-actions{display:flex;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid rgba(255,255,255,.1);flex-wrap:wrap;justify-content:center}.home-modal-action-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:.5rem;color:#e2e8f0;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .3s ease}.home-modal-action-btn:hover:not(:disabled){background:#ffffff1a;border-color:#06b6d480;transform:translateY(-2px)}.home-modal-action-btn:disabled{opacity:.5;cursor:not-allowed}.home-modal-action-btn svg{width:18px;height:18px}.home-modal-action-primary{background:linear-gradient(135deg,#10b981,#06b6d4);border-color:transparent;color:#fff}.home-modal-action-primary:hover{background:linear-gradient(135deg,#059669,#0891b2);transform:translateY(-2px);box-shadow:0 4px 12px #06b6d44d}.home-share-modal-content{position:relative;max-width:500px;width:100%;background:#1e293bf2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:1.5rem;border:1px solid rgba(255,255,255,.1);padding:2rem;animation:modalSlideIn .3s ease-out}.home-share-modal-header{text-align:center;margin-bottom:2rem}.home-share-modal-title{font-size:1.5rem;font-weight:700;color:#e2e8f0;margin-bottom:.5rem}.home-share-modal-subtitle{color:#94a3b8;font-size:.875rem}.home-share-qr-container{display:flex;justify-content:center;margin-bottom:2rem}.home-share-qr-code{padding:1.5rem;background:#fff;border-radius:1rem;box-shadow:0 8px 24px #0000004d}.home-share-url-container{display:flex;gap:.75rem;margin-bottom:2rem}.home-share-url-input{flex:1;padding:.75rem 1rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:.5rem;color:#e2e8f0;font-size:.875rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.home-share-url-input:focus{outline:none;border-color:#06b6d480}.home-share-copy-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:.5rem;color:#e2e8f0;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .3s ease;white-space:nowrap}.home-share-copy-btn:hover{background:#ffffff1a;border-color:#06b6d480}.home-share-copy-btn svg{width:18px;height:18px}.home-share-actions{display:flex;gap:.75rem;justify-content:center}.home-share-action-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:.5rem;color:#e2e8f0;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .3s ease}.home-share-action-btn:hover{background:#ffffff1a;border-color:#06b6d480;transform:translateY(-2px)}.home-share-action-btn svg{width:18px;height:18px}.home-share-action-primary{background:linear-gradient(135deg,#10b981,#06b6d4);border-color:transparent;color:#fff}.home-share-action-primary:hover{background:linear-gradient(135deg,#059669,#0891b2);box-shadow:0 4px 12px #06b6d44d}@media (max-width: 768px){.home-gallery-title{font-size:2rem}.home-modal-content{max-width:100vw;max-height:100vh;border-radius:0}.home-modal-image-container{min-height:300px;max-height:60vh;padding:1rem}.home-modal-info{flex-direction:column;align-items:flex-start;gap:.75rem}.home-modal-actions{flex-direction:column}.home-modal-action-btn{width:100%;justify-content:center}.home-share-modal-content{max-width:100%;padding:1.5rem}.home-share-url-container{flex-direction:column}.home-share-copy-btn{width:100%;justify-content:center}.home-share-actions{flex-direction:column}.home-share-action-btn{width:100%;justify-content:center}}.auth-container{display:flex;justify-content:center;align-items:center;min-height:calc(100vh - 200px);padding:2rem 1rem;position:relative;overflow:hidden}.auth-container:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#667eea,#764ba2);opacity:.05;animation:gradientMove 15s ease infinite;background-size:200% 200%}.auth-container:after{content:"";position:absolute;width:500px;height:500px;background:radial-gradient(circle,rgba(16,185,129,.1),transparent);border-radius:50%;top:-250px;right:-250px;animation:float 20s ease-in-out infinite}@keyframes float{0%,to{transform:translate(0) rotate(0)}33%{transform:translate(50px,-50px) rotate(120deg)}66%{transform:translate(-50px,50px) rotate(240deg)}}.auth-card{background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding:3rem 2.5rem;border-radius:2rem;box-shadow:0 20px 60px #0000001a,0 0 0 1px #ffffff80;width:100%;max-width:450px;position:relative;z-index:1;animation:slideUp .6s cubic-bezier(.34,1.56,.64,1);transition:all .3s ease}.auth-card:hover{box-shadow:0 25px 70px #00000026,0 0 0 1px #ffffff80;transform:translateY(-5px)}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.auth-card h2{margin-bottom:2rem;color:#1e293b;text-align:center;font-size:2rem;font-weight:800;background:linear-gradient(135deg,#10b981,#06b6d4,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;position:relative;padding-bottom:1rem}.auth-card h2:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:60px;height:4px;background:linear-gradient(90deg,#10b981,#06b6d4);border-radius:2px;animation:expandWidth .8s ease-out}@keyframes expandWidth{0%{width:0}to{width:60px}}.form-group{margin-bottom:1.75rem;position:relative}.form-group label{display:block;margin-bottom:.75rem;color:#374151;font-weight:600;font-size:.95rem;transition:color .3s ease}.form-group:focus-within label{color:#06b6d4}.form-group input{width:100%;padding:1rem 1.25rem;border:2px solid #e5e7eb;border-radius:1rem;font-size:1rem;transition:all .3s cubic-bezier(.4,0,.2,1);background:#f9fafb;color:#1e293b;box-sizing:border-box}.form-group input::-moz-placeholder{color:#9ca3af}.form-group input::placeholder{color:#9ca3af}.form-group input:focus{outline:none;border-color:#06b6d4;background:#fff;box-shadow:0 0 0 4px #06b6d41a,0 4px 12px #0000000d;transform:translateY(-2px)}.form-group input:hover:not(:focus){border-color:#d1d5db;background:#fff}.error{background:linear-gradient(135deg,#ef44441a,#dc26261a);color:#dc2626;padding:1rem 1.25rem;border-radius:1rem;margin-bottom:1.5rem;border:2px solid rgba(239,68,68,.3);font-weight:500;font-size:.95rem;animation:shake .5s ease-in-out;position:relative;overflow:hidden}.error:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmerError 2s ease-in-out infinite}@keyframes shimmerError{0%{left:-100%}to{left:100%}}.btn{width:100%;padding:1rem 1.5rem;border:none;border-radius:1rem;font-size:1rem;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;text-transform:uppercase;letter-spacing:.5px}.btn-primary{background:linear-gradient(135deg,#10b981,#06b6d4,#3b82f6);background-size:200% 200%;color:#fff;box-shadow:0 10px 30px #06b6d44d,0 0 #06b6d480;animation:gradientMove 3s ease infinite}.btn-primary:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#059669,#0891b2,#2563eb);opacity:0;transition:opacity .3s ease}.btn-primary span{position:relative;z-index:1}.btn-primary:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 15px 40px #06b6d466,0 0 0 4px #06b6d433}.btn-primary:hover:not(:disabled):before{opacity:1}.btn-primary:active:not(:disabled){transform:translateY(-1px)}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.btn-primary:disabled:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:loading 1.5s ease-in-out infinite}@keyframes loading{0%{transform:translate(-100%)}to{transform:translate(100%)}}@media (max-width: 640px){.auth-card{padding:2rem 1.5rem;border-radius:1.5rem}.auth-card h2{font-size:1.75rem}.form-group input{padding:.875rem 1rem}.btn{padding:.875rem 1.25rem}}@media (prefers-reduced-motion: reduce){.auth-container:before,.auth-container:after,.auth-card,.btn-primary{animation:none}.auth-card:hover{transform:none}}.photos-page{position:relative;overflow:hidden}.photos-page:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#10b98108,#06b6d408,#3b82f608);animation:gradientShift 15s ease infinite;background-size:200% 200%}@keyframes gradientShift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.floating-orb{position:absolute;border-radius:50%;filter:blur(60px);opacity:.1;animation:floatOrb 20s ease-in-out infinite}.orb-1{width:400px;height:400px;background:linear-gradient(135deg,#10b981,#06b6d4);top:-200px;right:-200px;animation-delay:0s}.orb-2{width:300px;height:300px;background:linear-gradient(135deg,#06b6d4,#3b82f6);bottom:-150px;left:-150px;animation-delay:7s}@keyframes floatOrb{0%,to{transform:translate(0) scale(1)}25%{transform:translate(50px,-50px) scale(1.1)}50%{transform:translate(-30px,30px) scale(.9)}75%{transform:translate(30px,50px) scale(1.05)}}.photos-header{background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:2rem;padding:2rem;margin-bottom:2rem;box-shadow:0 10px 40px #00000014,0 0 0 1px #ffffff80;animation:slideDown .6s ease-out;border:1px solid rgba(255,255,255,.5)}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.header-title{font-size:2.5rem;font-weight:800;background:linear-gradient(135deg,#10b981,#06b6d4,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.5rem}.header-subtitle{color:#64748b;font-size:1.1rem;font-weight:500}.header-actions{display:flex;flex-wrap:wrap;gap:1rem;margin-top:1.5rem}.action-btn{position:relative;padding:.875rem 1.75rem;border:none;border-radius:1rem;font-weight:700;font-size:1rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);overflow:hidden;display:inline-flex;align-items:center;gap:.5rem}.btn-primary-gradient{background:linear-gradient(135deg,#10b981,#06b6d4,#3b82f6);background-size:200% 200%;color:#fff;box-shadow:0 10px 30px #06b6d44d;animation:gradientMove 3s ease infinite}.btn-primary-gradient:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#059669,#0891b2,#2563eb);opacity:0;transition:opacity .3s ease}.btn-primary-gradient:hover{transform:translateY(-3px);box-shadow:0 15px 40px #06b6d466}.btn-primary-gradient:hover:before{opacity:1}@keyframes gradientMove{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.btn-secondary-gradient{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;box-shadow:0 10px 30px #8b5cf64d}.btn-secondary-gradient:hover{transform:translateY(-3px);box-shadow:0 15px 40px #8b5cf666}.action-btn span{position:relative;z-index:1}.action-btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.error-message{background:linear-gradient(135deg,#ef44441a,#dc26261a);border-left:4px solid #ef4444;color:#dc2626;padding:1rem 1.5rem;border-radius:1rem;margin-bottom:1.5rem;animation:shake .5s ease-in-out;display:flex;align-items:center;gap:.75rem;font-weight:500}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-5px)}20%,40%,60%,80%{transform:translate(5px)}}.empty-state{background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:2rem;padding:4rem 2rem;text-align:center;box-shadow:0 10px 40px #00000014,0 0 0 1px #ffffff80;animation:fadeIn .6s ease-out}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.empty-state-title{font-size:2rem;font-weight:700;color:#1e293b;margin-bottom:.75rem}.empty-state-text{font-size:1.1rem;color:#64748b;margin-bottom:2rem}.photos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;position:relative;z-index:1}@media (max-width: 768px){.photos-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}}.photo-card{background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:1.5rem;overflow:hidden;box-shadow:0 10px 30px #00000014,0 0 0 1px #ffffff80;transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;animation:fadeInUp .6s ease-out;animation-fill-mode:both}.photo-card:nth-child(1){animation-delay:.1s}.photo-card:nth-child(2){animation-delay:.2s}.photo-card:nth-child(3){animation-delay:.3s}.photo-card:nth-child(4){animation-delay:.4s}.photo-card:nth-child(5){animation-delay:.5s}.photo-card:nth-child(6){animation-delay:.6s}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.photo-card:hover{transform:translateY(-10px) scale(1.02);box-shadow:0 20px 50px #00000026,0 0 0 1px #ffffff80,0 0 30px #06b6d44d}.photo-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#10b9811a,#06b6d41a,#3b82f61a);opacity:0;transition:opacity .4s ease;z-index:1;pointer-events:none}.photo-card:hover:before{opacity:1}.photo-image-container{position:relative;aspect-ratio:1;overflow:hidden;background:linear-gradient(135deg,#f1f5f9,#e2e8f0)}.photo-image-container img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transition:transform .6s cubic-bezier(.4,0,.2,1)}.photo-card:hover .photo-image-container img{transform:scale(1.15) rotate(2deg)}.photo-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to bottom,transparent,rgba(0,0,0,.7));opacity:0;transition:opacity .4s ease;display:flex;align-items:flex-end;justify-content:center;padding:1.5rem;z-index:2}.photo-card:hover .photo-overlay{opacity:1}.delete-btn{padding:.75rem 1.5rem;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:none;border-radius:.75rem;font-weight:600;cursor:pointer;transition:all .3s ease;transform:translateY(10px);opacity:0;box-shadow:0 10px 25px #ef444466}.photo-card:hover .delete-btn{transform:translateY(0);opacity:1}.delete-btn:hover{transform:translateY(-2px) scale(1.05);box-shadow:0 15px 35px #ef444480}.delete-btn:active{transform:translateY(0) scale(.98)}.photo-info{padding:1.25rem;position:relative;z-index:1}.photo-name{font-weight:700;color:#1e293b;margin-bottom:.5rem;word-break:break-word;font-size:1.1rem;line-height:1.4}.photo-style-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.375rem .75rem;background:linear-gradient(135deg,#10b9811a,#06b6d41a);border-radius:.5rem;margin-bottom:.75rem;font-size:.85rem;font-weight:600;color:#059669}.style-icon{font-size:1rem}.style-name{color:#047857}.photo-meta{display:flex;flex-direction:column;gap:.5rem}.photo-date{font-size:.9rem;color:#64748b;display:flex;align-items:center;gap:.5rem}.photo-size{font-size:.85rem;color:#94a3b8}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1.5rem}.loading-spinner{width:60px;height:60px;border:4px solid rgba(6,182,212,.1);border-top-color:#06b6d4;border-radius:50%;animation:spin 1s linear infinite}.loading-text{font-size:1.25rem;color:#64748b;font-weight:500}@media (max-width: 640px){.photos-header{padding:1.5rem;border-radius:1.5rem}.header-title{font-size:2rem}.header-subtitle{font-size:1rem}.photos-grid{grid-template-columns:1fr}.empty-state{padding:3rem 1.5rem}.empty-state-title{font-size:1.5rem}}@media (prefers-reduced-motion: reduce){.floating-orb,.btn-primary-gradient,.photo-card,.loading-spinner{animation:none}.photo-card:hover{transform:none}}.style-card:hover .style-image{transform:scale(1.1)}.style-card:hover .style-image-overlay{opacity:1}.style-card:hover .style-card-action{color:#06b6d4}.style-card:hover .style-card-arrow{transform:translate(4px)}@media (prefers-reduced-motion: reduce){.floating-shape{animation:none}.style-card,.style-image,.style-card-arrow{transition:none}.style-card:hover{transform:none}}.grid-pattern{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(34,211,238,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(34,211,238,.03) 1px,transparent 1px);background-size:50px 50px;pointer-events:none}.floating-shape{position:absolute;border-radius:50%;opacity:.08;animation:float 25s infinite ease-in-out;will-change:transform}.shape-1{width:400px;height:400px;background:linear-gradient(135deg,#10b981,#06b6d4);top:-200px;left:-200px;animation-delay:0s;filter:blur(80px)}.shape-2{width:500px;height:500px;background:linear-gradient(135deg,#06b6d4,#3b82f6);bottom:-250px;right:-250px;animation-delay:6s;filter:blur(100px)}@keyframes float{0%,to{transform:translate(0) rotate(0) scale(1);opacity:.08}25%{transform:translate(60px,-60px) rotate(90deg) scale(1.15);opacity:.12}50%{transform:translate(-40px,40px) rotate(180deg) scale(.85);opacity:.06}75%{transform:translate(40px,60px) rotate(270deg) scale(1.1);opacity:.1}}@keyframes flash{0%{opacity:0}50%{opacity:1}to{opacity:0}}.animate-flash{animation:flash .3s ease-in-out}.camera-capture-fullscreen{position:fixed;top:0;left:0;right:0;bottom:0;width:100vw;height:100vh;z-index:9999;margin:0;padding:0;overflow:hidden}.camera-toast{position:fixed;top:24px;left:50%;transform:translate(-50%);z-index:10000;display:flex;align-items:center;gap:12px;padding:16px 24px;border-radius:12px;box-shadow:0 8px 24px #0000004d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:toastSlideIn .3s ease-out;min-width:300px;max-width:90%}.camera-toast.success{background:#10b981f2;color:#fff;border:1px solid rgba(255,255,255,.2)}.camera-toast.error{background:#ef4444f2;color:#fff;border:1px solid rgba(255,255,255,.2)}.camera-toast-icon{width:24px;height:24px;flex-shrink:0}@keyframes toastSlideIn{0%{opacity:0;transform:translate(-50%) translateY(-20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media (max-width: 768px){.floating-shape{opacity:.04}.shape-1,.shape-2{filter:blur(120px)}.grid-pattern{background-size:30px 30px;opacity:.5}}@media (prefers-reduced-motion: reduce){.floating-shape{animation:none}}.camera-control-btn{padding:14px 28px;font-size:16px;font-weight:600;border-radius:12px;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:8px;min-width:120px;box-shadow:0 4px 12px #0006,0 2px 4px #0000004d;border:2px solid;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.camera-btn-secondary{background:#ffffff40;color:#fff;border-color:#ffffff80;text-shadow:0 2px 4px rgba(0,0,0,.3)}.camera-btn-secondary:hover{background:#ffffff59;border-color:#ffffffb3;box-shadow:0 6px 16px #00000080,0 4px 8px #0006;transform:translateY(-2px)}.camera-btn-secondary:active{transform:translateY(0);box-shadow:0 2px 8px #0006}.camera-btn-primary{background:linear-gradient(135deg,#10b981,#06b6d4,#3b82f6);color:#fff;border-color:#ffffff4d;text-shadow:0 2px 4px rgba(0,0,0,.3)}.camera-btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#059669,#0891b2,#2563eb);box-shadow:0 8px 20px #10b98166,0 4px 8px #0000004d;transform:translateY(-2px)}.camera-btn-primary:active:not(:disabled){transform:translateY(0);box-shadow:0 4px 12px #10b9814d}.camera-btn-primary:disabled{opacity:.6;cursor:not-allowed}.camera-capture-btn{width:88px;height:88px;border-radius:50%;background:#fff;border:5px solid rgba(255,255,255,.8);box-shadow:0 0 0 4px #0000004d,0 8px 24px #00000080,0 4px 12px #0006,inset 0 2px 4px #fffc;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;position:relative;overflow:visible}.camera-capture-btn:before{content:"";position:absolute;top:-8px;right:-8px;bottom:-8px;left:-8px;border-radius:50%;border:3px solid rgba(255,255,255,.4);animation:pulse-ring 2s ease-out infinite}.camera-capture-btn:hover:not(:disabled){transform:scale(1.1);box-shadow:0 0 0 4px #0000004d,0 12px 32px #0009,0 6px 16px #00000080,inset 0 2px 4px #ffffffe6}.camera-capture-btn:active:not(:disabled){transform:scale(1.05);box-shadow:0 0 0 4px #0000004d,0 6px 16px #00000080,inset 0 2px 4px #fffc}.camera-capture-btn:disabled{opacity:.5;cursor:not-allowed;transform:scale(1)}.camera-capture-btn-inner{width:72px;height:72px;border-radius:50%;background:#fff;box-shadow:inset 0 2px 8px #0000001a,0 2px 4px #0003}@keyframes pulse-ring{0%{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.7}to{transform:scale(1.2);opacity:0}}@media (max-width: 768px){.camera-control-btn{padding:12px 20px;font-size:14px;min-width:100px}.camera-capture-btn{width:76px;height:76px}.camera-capture-btn-inner{width:60px;height:60px}}.camera-share-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000f2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:10001;display:flex;align-items:center;justify-content:center;padding:1rem;animation:fadeIn .3s ease-out}.camera-share-modal-content{position:relative;max-width:500px;width:100%;background:#1e293bf2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:1.5rem;border:1px solid rgba(255,255,255,.1);padding:2rem;animation:modalSlideIn .3s ease-out;box-shadow:0 20px 60px #00000080}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.camera-share-modal-close{position:absolute;top:1rem;right:1rem;width:40px;height:40px;border-radius:50%;background:#00000080;border:1px solid rgba(255,255,255,.2);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;transition:all .3s ease}.camera-share-modal-close:hover{background:#000000b3;transform:rotate(90deg)}.camera-share-modal-close svg{width:24px;height:24px}.camera-share-modal-header{text-align:center;margin-bottom:2rem;padding-top:.5rem}.camera-share-modal-title{font-size:1.75rem;font-weight:700;background:linear-gradient(to right,#10b981,#06b6d4,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.5rem}.camera-share-modal-subtitle{color:#94a3b8;font-size:.875rem}.camera-share-qr-container{display:flex;justify-content:center;margin-bottom:2rem}.camera-share-qr-code{padding:1.5rem;background:#fff;border-radius:1rem;box-shadow:0 8px 24px #0000004d}.camera-share-url-container{display:flex;gap:.75rem;margin-bottom:2rem}.camera-share-url-input{flex:1;padding:.75rem 1rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:.5rem;color:#e2e8f0;font-size:.875rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.camera-share-url-input:focus{outline:none;border-color:#06b6d480}.camera-share-copy-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:.5rem;color:#e2e8f0;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .3s ease;white-space:nowrap}.camera-share-copy-btn:hover{background:#ffffff1a;border-color:#06b6d480}.camera-share-copy-btn svg{width:18px;height:18px}.camera-share-actions{display:flex;gap:.75rem;justify-content:center}.camera-share-action-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:.5rem;color:#e2e8f0;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .3s ease}.camera-share-action-btn:hover{background:#ffffff1a;border-color:#06b6d480;transform:translateY(-2px)}.camera-share-action-btn svg{width:18px;height:18px}.camera-share-action-primary{background:linear-gradient(135deg,#10b981,#06b6d4);border-color:transparent;color:#fff}.camera-share-action-primary:hover{background:linear-gradient(135deg,#059669,#0891b2);box-shadow:0 4px 12px #06b6d44d}@media (max-width: 768px){.camera-share-modal-content{max-width:100%;padding:1.5rem}.camera-share-modal-title{font-size:1.5rem}.camera-share-url-container{flex-direction:column}.camera-share-copy-btn{width:100%;justify-content:center}.camera-share-actions{flex-direction:column}.camera-share-action-btn{width:100%;justify-content:center}.camera-share-qr-code{padding:1rem}.camera-share-qr-code svg{width:200px;height:200px}}.admin-dashboard{max-width:1200px;margin:0 auto}.admin-dashboard-header{margin-bottom:32px}.admin-features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-bottom:32px}.admin-feature-card{display:flex;align-items:center;gap:16px;padding:24px;background:#fff;border-radius:4px;box-shadow:0 2px 4px #0000001a,0 4px 8px #0000001a;text-decoration:none;color:inherit;transition:all .2s;cursor:pointer}.admin-feature-card:hover{box-shadow:0 4px 8px #0000001f,0 8px 16px #0000001f;transform:translateY(-2px)}.admin-feature-icon{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.admin-feature-icon-svg{width:32px;height:32px}.admin-feature-content{flex:1;min-width:0}.admin-feature-title{font-size:18px;font-weight:500;color:#212121;margin:0 0 4px}.admin-feature-description{font-size:14px;color:#757575;margin:0}.admin-feature-arrow{color:#757575;flex-shrink:0;transition:transform .2s}.admin-feature-card:hover .admin-feature-arrow{transform:translate(4px);color:#1976d2}.admin-stats-section{margin-top:32px}.admin-section-title{font-size:20px;font-weight:500;color:#212121;margin:0 0 16px}.admin-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.admin-stat-item{text-align:center;padding:16px;background:#f5f5f5;border-radius:4px}.admin-stat-value{font-size:32px;font-weight:600;color:#1976d2;margin-bottom:8px}.admin-stat-label{font-size:14px;color:#757575}.admin-error-page{display:flex;align-items:center;justify-content:center;min-height:400px}@media (max-width: 768px){.admin-features-grid,.admin-stats-grid{grid-template-columns:1fr}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes scale-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.animate-fade-in{animation:fade-in .3s ease-out}.animate-scale-in{animation:scale-in .3s ease-out}.overflow-y-auto::-webkit-scrollbar{width:8px}.overflow-y-auto::-webkit-scrollbar-track{background:#ffffff0d;border-radius:4px}.overflow-y-auto::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}.overflow-y-auto::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.line-clamp-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.photo-page{padding:24px;max-width:1400px;margin:0 auto;width:100%}.photo-page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;flex-wrap:wrap;gap:16px}.photo-page-title{font-size:28px;font-weight:500;color:#212121;margin:0 0 8px}.photo-page-subtitle{font-size:14px;color:#757575;margin:0}.photo-page-stats{display:flex;gap:12px}.photo-stat-card{background:#fff;border-radius:8px;padding:16px 20px;box-shadow:0 2px 4px #0000001a;display:flex;flex-direction:column;gap:4px;min-width:120px}.photo-stat-label{font-size:12px;color:#757575;text-transform:uppercase;letter-spacing:.5px}.photo-stat-value{font-size:24px;font-weight:600;color:#667eea}.photo-alert{padding:16px;border-radius:8px;margin-bottom:24px;display:flex;align-items:center;gap:12px;box-shadow:0 2px 4px #0000001a}.photo-alert.error{background:#ffebee;color:#c62828;border:1px solid #ef5350}.photo-icon{width:24px;height:24px;flex-shrink:0}.photo-search-container{margin-bottom:24px}.photo-search-input{position:relative;max-width:400px}.photo-search-input input{width:100%;padding:12px 16px 12px 48px;border:1px solid #e0e0e0;border-radius:8px;font-size:14px;transition:all .2s;background:#fff;box-shadow:0 1px 3px #0000001a}.photo-search-input input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.photo-search-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:#757575;width:20px;height:20px;pointer-events:none}.photo-clear-search{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:#757575;cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s}.photo-clear-search:hover{background:#f5f5f5;color:#424242}.photo-input{width:100%;padding:12px 16px;border:1px solid #e0e0e0;border-radius:8px;font-size:14px;transition:all .2s;background:#fff}.photo-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.photo-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px}.photo-loading-spinner{width:48px;height:48px;border:4px solid #e0e0e0;border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite}.photo-loading-text{color:#757575;font-size:14px}.photo-empty-state{text-align:center;padding:64px 24px;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.photo-empty-icon{width:64px;height:64px;color:#bdbdbd;margin:0 auto 16px}.photo-empty-title{font-size:20px;font-weight:500;color:#424242;margin:0 0 8px}.photo-empty-text{color:#757575;font-size:14px;margin:0}.photo-styles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px;margin-bottom:24px}.photo-style-card{background:#fff;border-radius:12px;overflow:hidden;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;box-shadow:0 2px 8px #0000001a;border:1px solid #e0e0e0}.photo-style-card:hover{transform:translateY(-8px);box-shadow:0 8px 24px #667eea33;border-color:#667eea}.photo-style-image-container{position:relative;width:100%;aspect-ratio:1;overflow:hidden;background:#f5f5f5}.photo-style-image{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transition:transform .5s cubic-bezier(.4,0,.2,1)}.photo-style-card:hover .photo-style-image{transform:scale(1.05)}.photo-style-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,#667eeae6,#764ba2b3);opacity:0;transition:opacity .3s;display:flex;align-items:center;justify-content:center}.photo-style-card:hover .photo-style-overlay{opacity:1}.photo-style-overlay-content{display:flex;flex-direction:column;align-items:center;gap:12px;color:#fff;font-weight:600;font-size:16px}.photo-style-play-icon{width:48px;height:48px}.photo-style-info{padding:20px;display:flex;flex-direction:column;gap:8px;flex:1}.photo-style-name{font-size:18px;font-weight:600;color:#212121;margin:0;line-height:1.3}.photo-style-description{font-size:14px;color:#757575;line-height:1.5;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;flex:1}.photo-style-action{display:flex;align-items:center;justify-content:space-between;margin-top:12px;padding-top:12px;border-top:1px solid #e0e0e0;color:#667eea;font-weight:600;font-size:14px;transition:color .3s}.photo-style-card:hover .photo-style-action{color:#764ba2}.photo-style-arrow-icon{width:20px;height:20px;transition:transform .3s}.photo-style-card:hover .photo-style-arrow-icon{transform:translate(4px)}@media (max-width: 768px){.photo-page{padding:16px}.photo-page-header{flex-direction:column}.photo-page-title{font-size:24px}.photo-styles-grid{grid-template-columns:1fr;gap:16px}.photo-search-input{max-width:100%}.photo-page-stats{width:100%}.photo-stat-card{flex:1}}@media (max-width: 480px){.photo-page{padding:12px}.photo-style-info{padding:16px}}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}#root{min-height:100vh}*{scroll-behavior:smooth}.collapse{visibility:collapse}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.inset-0{top:0;right:0;bottom:0;left:0}.bottom-8{bottom:2rem}.left-0{left:0}.right-0{right:0}.right-2{right:.5rem}.top-0{top:0}.top-2{top:.5rem}.top-4{top:1rem}.z-10{z-index:10}.z-20{z-index:20}.z-50{z-index:50}.m-0{margin:0}.mx-auto{margin-left:auto;margin-right:auto}.mb-1{margin-bottom:.25rem}.mb-12{margin-bottom:3rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.mt-1{margin-top:.25rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-auto{margin-top:auto}.line-clamp-2{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}.block{display:block}.inline-block{display:inline-block}.flex{display:flex}.table{display:table}.grid{display:grid}.hidden{display:none}.aspect-square{aspect-ratio:1 / 1}.h-16{height:4rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-64{height:16rem}.h-auto{height:auto}.h-full{height:100%}.max-h-\[90vh\]{max-height:90vh}.max-h-full{max-height:100%}.min-h-screen{min-height:100vh}.w-16{width:4rem}.w-5{width:1.25rem}.w-6{width:1.5rem}.w-auto{width:auto}.w-full{width:100%}.max-w-2xl{max-width:42rem}.max-w-6xl{max-width:72rem}.max-w-7xl{max-width:80rem}.max-w-\[1400px\]{max-width:1400px}.max-w-\[600px\]{max-width:600px}.max-w-full{max-width:100%}.max-w-md{max-width:28rem}.flex-1{flex:1 1 0%}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes spin{to{transform:rotate(360deg)}}.animate-spin{animation:spin 1s linear infinite}.cursor-pointer{cursor:pointer}.resize-none{resize:none}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.space-y-5>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.25rem * var(--tw-space-y-reverse))}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:1rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-xl{border-radius:.75rem}.border{border-width:1px}.border-4{border-width:4px}.border-b{border-bottom-width:1px}.border-b-2{border-bottom-width:2px}.border-t{border-top-width:1px}.border-red-500\/50{border-color:#ef444480}.border-slate-600{--tw-border-opacity: 1;border-color:rgb(71 85 105 / var(--tw-border-opacity, 1))}.border-white{--tw-border-opacity: 1;border-color:rgb(255 255 255 / var(--tw-border-opacity, 1))}.border-white\/10{border-color:#ffffff1a}.border-white\/20{border-color:#fff3}.border-t-transparent{border-top-color:transparent}.bg-black{--tw-bg-opacity: 1;background-color:rgb(0 0 0 / var(--tw-bg-opacity, 1))}.bg-black\/60{background-color:#0009}.bg-emerald-500\/20{background-color:#10b98133}.bg-emerald-500\/80{background-color:#10b981cc}.bg-gray-500\/20{background-color:#6b728033}.bg-gray-500\/80{background-color:#6b7280cc}.bg-gray-800{--tw-bg-opacity: 1;background-color:rgb(31 41 55 / var(--tw-bg-opacity, 1))}.bg-red-500\/20{background-color:#ef444433}.bg-red-500\/80{background-color:#ef4444cc}.bg-slate-600\/50{background-color:#47556980}.bg-slate-700\/30{background-color:#3341554d}.bg-slate-700\/50{background-color:#33415580}.bg-slate-800{--tw-bg-opacity: 1;background-color:rgb(30 41 59 / var(--tw-bg-opacity, 1))}.bg-white{--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))}.bg-white\/5{background-color:#ffffff0d}.bg-white\/70{background-color:#ffffffb3}.bg-gradient-to-br{background-image:linear-gradient(to bottom right,var(--tw-gradient-stops))}.bg-gradient-to-r{background-image:linear-gradient(to right,var(--tw-gradient-stops))}.bg-gradient-to-t{background-image:linear-gradient(to top,var(--tw-gradient-stops))}.from-black\/60{--tw-gradient-from: rgb(0 0 0 / .6) var(--tw-gradient-from-position);--tw-gradient-to: rgb(0 0 0 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-blue-600{--tw-gradient-from: #2563eb var(--tw-gradient-from-position);--tw-gradient-to: rgb(37 99 235 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-emerald-400{--tw-gradient-from: #34d399 var(--tw-gradient-from-position);--tw-gradient-to: rgb(52 211 153 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-emerald-500{--tw-gradient-from: #10b981 var(--tw-gradient-from-position);--tw-gradient-to: rgb(16 185 129 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-slate-50{--tw-gradient-from: #f8fafc var(--tw-gradient-from-position);--tw-gradient-to: rgb(248 250 252 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-slate-900{--tw-gradient-from: #0f172a var(--tw-gradient-from-position);--tw-gradient-to: rgb(15 23 42 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.via-cyan-400{--tw-gradient-to: rgb(34 211 238 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), #22d3ee var(--tw-gradient-via-position), var(--tw-gradient-to)}.via-purple-50{--tw-gradient-to: rgb(250 245 255 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), #faf5ff var(--tw-gradient-via-position), var(--tw-gradient-to)}.via-purple-900{--tw-gradient-to: rgb(88 28 135 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), #581c87 var(--tw-gradient-via-position), var(--tw-gradient-to)}.via-transparent{--tw-gradient-to: rgb(0 0 0 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), transparent var(--tw-gradient-via-position), var(--tw-gradient-to)}.to-blue-400{--tw-gradient-to: #60a5fa var(--tw-gradient-to-position)}.to-blue-50{--tw-gradient-to: #eff6ff var(--tw-gradient-to-position)}.to-cyan-400{--tw-gradient-to: #22d3ee var(--tw-gradient-to-position)}.to-cyan-500{--tw-gradient-to: #06b6d4 var(--tw-gradient-to-position)}.to-slate-900{--tw-gradient-to: #0f172a var(--tw-gradient-to-position)}.to-transparent{--tw-gradient-to: transparent var(--tw-gradient-to-position)}.bg-clip-text{-webkit-background-clip:text;background-clip:text}.object-contain{-o-object-fit:contain;object-fit:contain}.object-cover{-o-object-fit:cover;object-fit:cover}.p-2{padding:.5rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-16{padding-top:4rem;padding-bottom:4rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-8{padding-top:2rem;padding-bottom:2rem}.pt-3{padding-top:.75rem}.pt-4{padding-top:1rem}.text-center{text-align:center}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-extrabold{font-weight:800}.font-semibold{font-weight:600}.leading-relaxed{line-height:1.625}.text-cyan-400{--tw-text-opacity: 1;color:rgb(34 211 238 / var(--tw-text-opacity, 1))}.text-emerald-400{--tw-text-opacity: 1;color:rgb(52 211 153 / var(--tw-text-opacity, 1))}.text-emerald-500{--tw-text-opacity: 1;color:rgb(16 185 129 / var(--tw-text-opacity, 1))}.text-gray-400{--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity, 1))}.text-red-200{--tw-text-opacity: 1;color:rgb(254 202 202 / var(--tw-text-opacity, 1))}.text-red-400{--tw-text-opacity: 1;color:rgb(248 113 113 / var(--tw-text-opacity, 1))}.text-slate-200{--tw-text-opacity: 1;color:rgb(226 232 240 / var(--tw-text-opacity, 1))}.text-slate-300{--tw-text-opacity: 1;color:rgb(203 213 225 / var(--tw-text-opacity, 1))}.text-slate-400{--tw-text-opacity: 1;color:rgb(148 163 184 / var(--tw-text-opacity, 1))}.text-transparent{color:transparent}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.opacity-0{opacity:0}.shadow-2xl{--tw-shadow: 0 25px 50px -12px rgb(0 0 0 / .25);--tw-shadow-colored: 0 25px 50px -12px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-lg{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-black\/5{--tw-shadow-color: rgb(0 0 0 / .05);--tw-shadow: var(--tw-shadow-colored)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-blur-md{--tw-backdrop-blur: blur(12px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.backdrop-blur-sm{--tw-backdrop-blur: blur(4px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.backdrop-blur-xl{--tw-backdrop-blur: blur(24px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-300{transition-duration:.3s}.duration-500{transition-duration:.5s}@keyframes slideInFromLeft{0%{opacity:0;transform:translate(-50px)}to{opacity:1;transform:translate(0)}}@keyframes slideInFromRight{0%{opacity:0;transform:translate(50px)}to{opacity:1;transform:translate(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes glow{0%,to{box-shadow:0 0 20px #06b6d466}50%{box-shadow:0 0 40px #06b6d4cc}}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:#0000000d;border-radius:10px}::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#10b981,#06b6d4);border-radius:10px;-webkit-transition:background .3s ease;transition:background .3s ease}::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#059669,#0891b2)}::selection{background:#06b6d44d;color:inherit}::-moz-selection{background:#06b6d44d;color:inherit}:focus-visible{outline:2px solid #06b6d4;outline-offset:2px;border-radius:4px}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}.shimmer{background:linear-gradient(to right,#f0f0f0,#e0e0e0,#f0f0f0 40%,#f0f0f0);background-size:1000px 100%;animation:shimmer 2s infinite linear}@keyframes gradientText{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.animate-gradient-text{background-size:200% 200%;animation:gradientText 3s ease infinite}.file\:mr-4::file-selector-button{margin-right:1rem}.file\:rounded-lg::file-selector-button{border-radius:.5rem}.file\:border-0::file-selector-button{border-width:0px}.file\:bg-emerald-500::file-selector-button{--tw-bg-opacity: 1;background-color:rgb(16 185 129 / var(--tw-bg-opacity, 1))}.file\:px-4::file-selector-button{padding-left:1rem;padding-right:1rem}.file\:py-2::file-selector-button{padding-top:.5rem;padding-bottom:.5rem}.file\:text-sm::file-selector-button{font-size:.875rem;line-height:1.25rem}.file\:font-semibold::file-selector-button{font-weight:600}.file\:text-white::file-selector-button{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.hover\:-translate-y-1:hover{--tw-translate-y: -.25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:border-emerald-400\/50:hover{border-color:#34d39980}.hover\:bg-red-600:hover{--tw-bg-opacity: 1;background-color:rgb(220 38 38 / var(--tw-bg-opacity, 1))}.hover\:bg-slate-600:hover{--tw-bg-opacity: 1;background-color:rgb(71 85 105 / var(--tw-bg-opacity, 1))}.hover\:bg-white\/10:hover{background-color:#ffffff1a}.hover\:text-white:hover{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.hover\:shadow-\[0_20px_40px_rgba\(0\,0\,0\,0\.4\)\,0_0_20px_rgba\(16\,185\,129\,0\.2\)\]:hover{--tw-shadow: 0 20px 40px rgba(0,0,0,.4),0 0 20px rgba(16,185,129,.2);--tw-shadow-colored: 0 20px 40px var(--tw-shadow-color), 0 0 20px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.hover\:shadow-lg:hover{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.hover\:shadow-xl:hover{--tw-shadow: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.hover\:file\:bg-emerald-600::file-selector-button:hover{--tw-bg-opacity: 1;background-color:rgb(5 150 105 / var(--tw-bg-opacity, 1))}.focus\:border-emerald-500:focus{--tw-border-opacity: 1;border-color:rgb(16 185 129 / var(--tw-border-opacity, 1))}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-2:focus{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus\:ring-emerald-500:focus{--tw-ring-opacity: 1;--tw-ring-color: rgb(16 185 129 / var(--tw-ring-opacity, 1))}.focus\:ring-emerald-500\/50:focus{--tw-ring-color: rgb(16 185 129 / .5)}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}.group:hover .group-hover\:scale-110{--tw-scale-x: 1.1;--tw-scale-y: 1.1;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@media (min-width: 640px){.sm\:h-20{height:5rem}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.sm\:p-8{padding:2rem}.sm\:px-6{padding-left:1.5rem;padding-right:1.5rem}.sm\:text-3xl{font-size:1.875rem;line-height:2.25rem}}@media (min-width: 768px){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:gap-8{gap:2rem}.md\:text-5xl{font-size:3rem;line-height:1}}@media (min-width: 1024px){.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:px-8{padding-left:2rem;padding-right:2rem}}@media (min-width: 1280px){.xl\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}
