@import"https://fonts.googleapis.com/css2?family=Sora:wght@400;500;600;700;800&family=Nunito:wght@400;500;700&display=swap";:root{--color-background: #FFFFFF;--color-primary: #1E293B;--color-primary-dark: #0F172A;--color-primary-light: #334155;--color-accent: #4F46E5;--color-accent-light: #818CF8;--color-accent-dark: #4338CA;--color-secondary: #EC4899;--color-secondary-light: #F472B6;--color-tertiary: #14B8A6;--color-tertiary-light: #2DD4BF;--color-gray-50: #F8FAFC;--color-gray-100: #F1F5F9;--color-gray-200: #E2E8F0;--color-gray-300: #CBD5E1;--color-gray-400: #94A3B8;--color-gray-500: #64748B;--color-gray-600: #475569;--color-gray-700: #334155;--color-gray-800: #1E293B;--color-gray-900: #0F172A;--gradient-primary: linear-gradient(135deg, #4F46E5 0%, #4338CA 100%);--gradient-accent: linear-gradient(135deg, #4F46E5 0%, #6366F1 100%);--gradient-secondary: linear-gradient(135deg, #EC4899 0%, #DB2777 100%);--gradient-tertiary: linear-gradient(135deg, #14B8A6 0%, #0D9488 100%);--gradient-cool: linear-gradient(135deg, #4F46E5 0%, #14B8A6 100%);--gradient-warm: linear-gradient(135deg, #EC4899 0%, #EAB308 100%);--shadow-sm: 0 1px 3px rgba(15, 23, 42, .1);--shadow-md: 0 4px 6px -1px rgba(15, 23, 42, .1), 0 2px 4px -1px rgba(15, 23, 42, .06);--shadow-lg: 0 10px 15px -3px rgba(15, 23, 42, .1), 0 4px 6px -2px rgba(15, 23, 42, .05);--shadow-xl: 0 20px 25px -5px rgba(15, 23, 42, .1), 0 10px 10px -5px rgba(15, 23, 42, .04);--shadow-inner: inset 0 2px 4px 0 rgba(15, 23, 42, .06);--shadow-outline: 0 0 0 3px rgba(79, 70, 229, .45);--radius-sm: .125rem;--radius-md: .375rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-3xl: 2rem;--radius-full: 9999px;--font-sans: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-display: "Inter", "SF Pro Display", system-ui, sans-serif;--font-mono: "JetBrains Mono", "SF Mono", monospace;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-normal: .3s cubic-bezier(.4, 0, .2, 1);--transition-slow: .5s cubic-bezier(.4, 0, .2, 1);--transition-bounce: .5s cubic-bezier(.34, 1.56, .64, 1);--header-height: 4rem;--container-padding: 2rem}@media(max-width:768px){:root{--container-padding: 1.25rem;--header-height: 3.5rem}}*{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth;scroll-padding-top:calc(var(--header-height) + 1rem)}body{font-family:var(--font-sans);background-color:var(--color-background);color:var(--color-primary);line-height:1.5;font-weight:400;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;overflow-x:hidden}a{color:var(--color-accent);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-accent-dark)}button{font-family:inherit;cursor:pointer;background:none;border:none}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:700;line-height:1.2;color:var(--color-primary-dark);letter-spacing:-.01em}ul{list-style-type:none}.app{display:flex;flex-direction:column;min-height:100vh}.container{width:100%;max-width:1280px;margin:0 auto;padding-left:var(--container-padding);padding-right:var(--container-padding)}main{flex:1}section{position:relative;overflow:hidden}.header{position:fixed;top:0;left:0;right:0;height:var(--header-height);background:#fffc;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);z-index:100;transition:all var(--transition-normal)}.header.scrolled{background:#fffffff2;box-shadow:var(--shadow-md)}.header-content{display:flex;align-items:center;justify-content:space-between;height:100%}.logo{display:flex;align-items:center;gap:.75rem}.logo-icon{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;color:var(--color-accent)}.logo-text{font-size:1.25rem;font-weight:700;color:var(--color-primary-dark)}.desktop-nav{display:flex;align-items:center}.desktop-nav ul{display:flex;gap:1.5rem}.nav-link{padding:.5rem .75rem;color:var(--color-gray-600);font-weight:500;position:relative;transition:color var(--transition-fast)}.nav-link:hover,.nav-link.active{color:var(--color-primary-dark)}.nav-indicator{position:absolute;bottom:-3px;left:.5rem;right:.5rem;height:2px;background:var(--color-accent);border-radius:var(--radius-full)}.header-demo-button{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--gradient-accent);color:#fff;font-weight:500;border-radius:var(--radius-lg);transition:transform var(--transition-fast),box-shadow var(--transition-fast);box-shadow:var(--shadow-sm)}.header-demo-button:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.mobile-menu-toggle{display:none;flex-direction:column;justify-content:space-between;width:1.5rem;height:1.25rem;background:transparent;border:none;cursor:pointer}.mobile-menu-toggle span{display:block;width:100%;height:2px;background-color:var(--color-primary);transition:transform var(--transition-fast),opacity var(--transition-fast)}.mobile-menu-toggle.open span:first-child{transform:translateY(8px) rotate(45deg)}.mobile-menu-toggle.open span:nth-child(2){opacity:0}.mobile-menu-toggle.open span:last-child{transform:translateY(-8px) rotate(-45deg)}.mobile-menu{position:absolute;top:var(--header-height);left:0;right:0;background:var(--color-background);box-shadow:var(--shadow-md);padding:1.5rem 0}.mobile-nav ul{display:flex;flex-direction:column;gap:.75rem}.mobile-nav .nav-link{display:block;padding:.75rem 0;text-align:center}.mobile-demo-button{display:flex;align-items:center;justify-content:center;gap:.5rem;margin:1.5rem auto 0;padding:.75rem 1.5rem;background:var(--gradient-accent);color:#fff;font-weight:500;border-radius:var(--radius-lg);transition:transform var(--transition-fast),box-shadow var(--transition-fast);box-shadow:var(--shadow-sm);width:80%}@media(max-width:768px){.desktop-nav,.header-demo-button{display:none}.mobile-menu-toggle{display:flex}}.hero{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:5rem 0 3rem;position:relative;overflow:hidden}.hero-backdrop{position:absolute;top:0;left:0;width:100%;height:100%;z-index:-1;overflow:hidden}.backdrop-gradient{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#f8faff,#eef2ff,#f8faff)}.backdrop-grid{position:absolute;top:0;left:0;width:100%;height:100%;background-size:40px 40px;background-image:linear-gradient(to right,rgba(99,102,241,.05) 1px,transparent 1px),linear-gradient(to bottom,rgba(99,102,241,.05) 1px,transparent 1px);opacity:.6}.hero-content{display:flex;align-items:center;justify-content:space-between;gap:3rem;margin-top:3rem;z-index:1;position:relative}.hero-left{flex:1;max-width:600px}.hero-title{font-size:3.75rem;font-weight:700;line-height:1.1;margin-bottom:1.5rem;background:var(--gradient-primary);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.login-cta-section{padding:2rem 0}.login-cta-section .card-text{text-align:center;color:var(--color-gray-600);font-size:1.0625rem;margin-bottom:2rem;line-height:1.7}.login-cta-section .cta-buttons{display:flex;gap:1rem;justify-content:center;align-items:center;flex-wrap:wrap;margin-top:2rem}.login-cta-section .hero-button{min-width:280px}.content-section{padding:3rem 0;min-height:calc(100vh - var(--header-height));background:linear-gradient(to bottom,#f8faff,#fff,#f8faff)}.admin-panel{max-width:1200px;margin:0 auto}.admin-panel h2{font-size:2.5rem;margin-bottom:2rem;text-align:center;color:var(--color-primary-dark);font-weight:800;letter-spacing:-.02em}.section-header{margin-bottom:1.5rem}.section-header h3{font-size:1.5rem;color:var(--color-primary-dark);margin-bottom:.5rem;font-weight:700;letter-spacing:-.01em}.training-control-section{background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:2rem;border-radius:var(--border-radius-xl);box-shadow:0 8px 32px #00000014;margin-bottom:2rem;border:1px solid rgba(255,255,255,.5);transition:all var(--transition);position:relative;overflow:hidden}.training-control-section:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(135deg,#6366f1,#ec4899);opacity:0;transition:opacity var(--transition)}.training-control-section:hover{transform:translateY(-4px);box-shadow:0 20px 40px #6366f126}.training-control-section:hover:before{opacity:1}.toggle-button{padding:.75rem 1.5rem;border:2px solid var(--color-gray-300);border-radius:var(--border-radius-lg);background:#fff;color:var(--color-gray-600);font-weight:600;cursor:pointer;transition:all var(--transition);min-width:80px;position:relative;overflow:hidden}.toggle-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(99,102,241,.1),transparent);transition:left .6s}.toggle-button:hover:before{left:100%}.toggle-button.active{border-color:#6366f1;background:linear-gradient(135deg,#6366f1,#ec4899);color:#fff;box-shadow:0 4px 12px #6366f14d}.toggle-button:hover:not(.active){border-color:#6366f1;color:#6366f1;transform:translateY(-1px)}.training-notification{padding:1rem;background:#6366f10d;border-radius:var(--border-radius-lg);border-left:4px solid #6366F1;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.training-notification p{color:var(--color-gray-700);font-weight:500}.progress-bar{width:100%;height:8px;background:var(--color-gray-200);border-radius:var(--radius-full);margin-top:1rem;overflow:hidden}.progress{height:100%;background:linear-gradient(135deg,#6366f1,#ec4899);transition:width .5s cubic-bezier(.4,0,.2,1);border-radius:var(--radius-full);box-shadow:0 0 10px #6366f180}.training-analytics{background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:2rem;border-radius:var(--border-radius-xl);box-shadow:0 8px 32px #00000014;margin-bottom:2rem;border:1px solid rgba(255,255,255,.5);transition:all var(--transition);position:relative;overflow:hidden}.training-analytics:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(135deg,#6366f1,#ec4899);opacity:0;transition:opacity var(--transition)}.training-analytics:hover{transform:translateY(-4px);box-shadow:0 20px 40px #6366f126}.training-analytics:hover:before{opacity:1}.analytics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.metric-card{padding:1.75rem;background:#fffc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--border-radius-lg);text-align:center;border:1px solid rgba(99,102,241,.1);transition:all var(--transition-bounce);position:relative;overflow:hidden}.metric-card:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#6366f1,#ec4899);opacity:0;transition:opacity var(--transition);z-index:0}.metric-card:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 12px 24px #6366f133;border-color:#6366f14d}.metric-card:hover:before{opacity:.05}.metric-title{font-size:.875rem;font-weight:600;color:var(--color-gray-600);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem;position:relative;z-index:1}.metric-value{font-size:2rem;font-weight:700;color:var(--color-primary-dark);background:linear-gradient(135deg,#6366f1,#ec4899);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;position:relative;z-index:1}.photos-section{background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:2rem;border-radius:var(--border-radius-xl);box-shadow:0 8px 32px #00000014;border:1px solid rgba(255,255,255,.5);transition:all var(--transition);position:relative;overflow:hidden}.photos-section:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(135deg,#6366f1,#ec4899);opacity:0;transition:opacity var(--transition)}.photos-section:hover:before{opacity:1}.folder-item{border:1px solid rgba(99,102,241,.1);border-radius:var(--border-radius-lg);overflow:hidden;transition:all var(--transition-bounce);background:#fffc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.folder-item:hover{box-shadow:0 12px 24px #6366f126;transform:translateY(-2px);border-color:#6366f133}.folder-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;background:#f8faff80;cursor:pointer;transition:background-color var(--transition)}.folder-header:hover{background:#6366f10d}.folder-icon{transition:transform var(--transition-normal);color:var(--color-gray-400)}.folder-details{padding:1.5rem;background:#fff}.subfolder-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:var(--color-gray-50);border-radius:var(--radius-md)}.view-photos-button,.view-all-photos-button{padding:.5rem 1rem;background:linear-gradient(135deg,#6366f1,#ec4899);color:#fff;border:none;border-radius:var(--border-radius-lg);font-weight:500;cursor:pointer;transition:all var(--transition);font-size:.875rem;box-shadow:0 4px 8px #6366f133;position:relative;overflow:hidden}.view-photos-button:before,.view-all-photos-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s}.view-photos-button:hover:before,.view-all-photos-button:hover:before{left:100%}.view-photos-button:hover,.view-all-photos-button:hover{transform:translateY(-2px);box-shadow:0 8px 16px #6366f14d}.view-photos-btn,.view-all-photos-btn{padding:.5rem 1rem;background:linear-gradient(135deg,#6366f1,#ec4899);color:#fff;border:none;border-radius:var(--border-radius-lg);font-weight:500;cursor:pointer;transition:all var(--transition);font-size:.875rem;box-shadow:0 4px 8px #6366f133;position:relative;overflow:hidden}.view-photos-btn:before,.view-all-photos-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s}.view-photos-btn:hover:before,.view-all-photos-btn:hover:before{left:100%}.view-photos-btn:hover,.view-all-photos-btn:hover{transform:translateY(-2px);box-shadow:0 8px 16px #6366f14d}.photos-actions-bar{display:flex;gap:1rem;justify-content:space-between;margin-bottom:2rem;flex-wrap:wrap}.photographer-panel h2{font-size:2.5rem;margin-bottom:2rem;text-align:center;color:var(--color-primary-dark)}.upload-section{background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:2rem;border-radius:var(--border-radius-xl);box-shadow:0 8px 32px #00000014;margin-bottom:2rem;border:1px solid rgba(255,255,255,.5);transition:all var(--transition);position:relative;overflow:hidden}.upload-section:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(135deg,#6366f1,#ec4899);opacity:0;transition:opacity var(--transition)}.upload-section:hover:before{opacity:1}.upload-controls p{margin-bottom:1rem;color:var(--color-gray-700)}.upload-button{display:inline-flex;align-items:center;gap:.5rem;padding:1rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:var(--border-radius-lg);font-weight:600;cursor:pointer;transition:all var(--transition);box-shadow:0 10px 20px #667eea4d;position:relative;overflow:hidden}.upload-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s}.upload-button:hover:before{left:100%}.upload-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 15px 30px #667eea66}.upload-button:disabled{opacity:.5;cursor:not-allowed}.training-locked-message{margin-top:1rem;padding:1rem;background:var(--color-gray-100);border:1px solid var(--color-gray-300);border-radius:var(--radius-md)}.training-locked-message p{color:var(--color-gray-700);font-weight:500;margin:0}.upload-success{margin-top:1.5rem;padding:1rem;background:#22c55e1a;border:1px solid rgba(34,197,94,.2);border-radius:var(--radius-md)}.upload-success h4{color:#22c55e;margin-bottom:.5rem}.upload-success p{color:#22c55e;margin:0}.attendee-panel{max-width:1000px;margin:0 auto}.welcome-header{text-align:center;margin-bottom:2rem}.welcome-header h2{font-size:2.5rem;color:var(--color-primary-dark);font-weight:800;letter-spacing:-.02em;background:linear-gradient(135deg,#6366f1,#ec4899);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.profile-section{display:flex;align-items:center;gap:2rem;background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:2rem;border-radius:var(--border-radius-xl);box-shadow:0 8px 32px #00000014;margin-bottom:2rem;border:1px solid rgba(255,255,255,.5);transition:all var(--transition);position:relative;overflow:hidden}.profile-section:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(135deg,#14b8a6,#0891b2);opacity:0;transition:opacity var(--transition)}.profile-section:hover:before{opacity:1}.profile-section:hover{transform:translateY(-4px);box-shadow:0 20px 40px #14b8a626}.profile-image{flex-shrink:0}.profile-image img{width:120px;height:120px;border-radius:50%;object-fit:cover;border:4px solid transparent;background:linear-gradient(#fff,#fff) padding-box,linear-gradient(135deg,#14b8a6,#0891b2) border-box;box-shadow:0 8px 24px #14b8a64d}.my-photos-section{text-align:center;background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:3rem 2rem;border-radius:var(--border-radius-xl);box-shadow:0 8px 32px #00000014;border:1px solid rgba(255,255,255,.5);transition:all var(--transition);position:relative;overflow:hidden}.my-photos-section:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(135deg,#14b8a6,#0891b2);opacity:0;transition:opacity var(--transition)}.my-photos-section:hover:before{opacity:1}.view-my-photos-button{display:inline-flex;align-items:center;gap:.5rem;padding:1.25rem 2.5rem;background:linear-gradient(135deg,#14b8a6,#0891b2);color:#fff;border:none;border-radius:var(--border-radius-lg);font-size:1.1rem;font-weight:600;cursor:pointer;transition:all var(--transition);box-shadow:0 10px 20px #14b8a64d;margin-bottom:1.5rem;position:relative;overflow:hidden}.view-my-photos-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s}.view-my-photos-button:hover:before{left:100%}.view-my-photos-button:hover{transform:translateY(-2px);box-shadow:0 15px 30px #14b8a666}.event-details h3{font-size:1.5rem;color:var(--color-primary-dark);margin-bottom:.5rem;font-weight:700;letter-spacing:-.01em}.event-date,.event-location{color:var(--color-gray-600);margin-bottom:.25rem;font-size:1rem}.photo-count-info{color:var(--color-gray-700);font-size:1.1rem;line-height:1.6}.viewing-photos-section{background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:2rem;border-radius:var(--border-radius-xl);box-shadow:0 8px 32px #00000014;border:1px solid rgba(255,255,255,.5);transition:all var(--transition);position:relative;overflow:hidden}.viewing-photos-section:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(135deg,#14b8a6,#0891b2);opacity:0;transition:opacity var(--transition)}.viewing-photos-section:hover:before{opacity:1}.photos-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.photos-header h3{font-size:1.5rem;color:var(--color-primary-dark);font-weight:700;letter-spacing:-.01em}.photos-actions{display:flex;gap:1rem}.back-button,.download-button{padding:.75rem 1.5rem;border:none;border-radius:var(--border-radius-lg);font-weight:500;cursor:pointer;transition:all var(--transition);position:relative;overflow:hidden}.back-button{background:var(--color-gray-200);color:var(--color-gray-700)}.back-button:hover{background:var(--color-gray-300);transform:translateY(-1px)}.download-button{background:linear-gradient(135deg,#14b8a6,#0891b2);color:#fff;box-shadow:0 4px 12px #14b8a64d}.download-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s}.download-button:hover:before{left:100%}.download-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 16px #14b8a666}.download-button:disabled{opacity:.5;cursor:not-allowed}.training-locked-message{margin-top:1rem;padding:1rem;background:#ef44440d;border:1px solid rgba(239,68,68,.2);border-radius:var(--border-radius-lg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.training-locked-message p{color:#ef4444;font-weight:500;margin:0}.upload-success{margin-top:1.5rem;padding:1rem;background:#22c55e1a;border:1px solid rgba(34,197,94,.2);border-radius:var(--border-radius-lg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.upload-success h4{color:#22c55e;margin-bottom:.5rem;font-weight:700}.upload-success p{color:#22c55e;margin:0;font-weight:500}.subfolder-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:#f8faffcc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--border-radius-lg);transition:all var(--transition);border:1px solid rgba(99,102,241,.05)}.subfolder-item:hover{background:#6366f10d;transform:translate(4px);border-color:#6366f11a}.subfolder-name{font-weight:500;color:var(--color-gray-700)}.photo-count{color:var(--color-gray-500);font-size:.875rem}.folder-name{font-weight:600;color:var(--color-primary-dark);font-size:1.1rem}.folder-info{color:var(--color-gray-600);font-size:.875rem}.folder-icon{transition:transform var(--transition);color:var(--color-gray-400);font-size:1.25rem}.folder-icon.expanded{transform:rotate(180deg)}.folder-details{padding:1.5rem;background:#ffffff80;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.subfolder-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.folder-actions{display:flex;justify-content:center}.photos-section.view-only .section-header .helper-text{font-size:.875rem;color:var(--color-gray-500);margin-top:.5rem}.folder-list{display:flex;flex-direction:column;gap:1rem}.upload-controls p{margin-bottom:1rem;color:var(--color-gray-700);font-size:1rem}.photographer-panel{max-width:1200px;margin:0 auto}.photographer-panel h2{font-size:2.5rem;margin-bottom:2rem;text-align:center;color:var(--color-primary-dark);font-weight:800;letter-spacing:-.02em}.toggle-option{display:flex;align-items:center;justify-content:space-between;gap:1rem}.toggle-option span{font-size:1.1rem;font-weight:500;color:var(--color-gray-700)}.training-lock{display:flex;flex-direction:column;gap:1rem}.photos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.photo-item{background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--border-radius-xl);overflow:hidden;box-shadow:0 8px 32px #00000014;transition:all var(--transition-bounce);border:1px solid rgba(255,255,255,.5);position:relative}.photo-item:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(135deg,#6366f1,#ec4899);transform:scaleX(0);transition:transform var(--transition)}.photo-item:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 20px 40px #6366f126}.photo-item:hover:before{transform:scaleX(1)}.photo-item img{width:100%;height:200px;object-fit:cover;display:block}.photo-title{padding:1rem;font-weight:500;color:var(--color-gray-700);text-align:center;font-size:.9375rem}.photo-modal{position:fixed;inset:0;background:#0f172ae6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:1000;display:flex;flex-direction:column;animation:fadeIn .3s ease-out}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 2rem;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(99,102,241,.1);box-shadow:0 2px 12px #0000000d}.modal-header h3{font-size:1.25rem;color:var(--color-primary-dark);font-weight:700;letter-spacing:-.01em}.close-button{width:2.5rem;height:2.5rem;border:none;background:var(--color-gray-100);color:var(--color-gray-600);border-radius:50%;font-size:1.5rem;cursor:pointer;transition:all var(--transition);display:flex;align-items:center;justify-content:center}.close-button:hover{background:var(--color-gray-200);color:var(--color-gray-800);transform:rotate(90deg)}.modal-content{flex:1;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:2rem;overflow-y:auto}.default-view{text-align:center;padding:3rem 2rem;background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--border-radius-xl);box-shadow:0 8px 32px #00000014;max-width:600px;margin:0 auto;border:1px solid rgba(255,255,255,.5)}.default-view h2{font-size:1.75rem;margin-bottom:1rem;color:var(--color-primary-dark);font-weight:700;letter-spacing:-.01em}.default-view p{color:var(--color-gray-600);margin-bottom:2rem;font-size:1.1rem;line-height:1.7}.default-view .login-button{background:linear-gradient(135deg,#6366f1,#ec4899);min-width:auto;box-shadow:0 10px 20px #6366f14d}.model-hero{background:linear-gradient(135deg,#0f172a,#1e293b,#334155);padding:5rem 0 3rem;color:#fff;text-align:center;position:relative;overflow:hidden}.model-hero:before{content:"";position:absolute;top:-50%;right:-20%;width:800px;height:800px;background:radial-gradient(circle,rgba(99,102,241,.15) 0%,transparent 70%);animation:pulse 10s ease-in-out infinite}.model-hero h1{font-size:3rem;margin-bottom:1rem;color:#fff;background:none;-webkit-text-fill-color:white;font-weight:800;letter-spacing:-.02em;position:relative;z-index:1}.model-hero p{font-size:1.25rem;opacity:.9;line-height:1.7;position:relative;z-index:1}@media(max-width:1024px){.hero-section .hero-content h1{font-size:2.5rem}.profile-section{flex-direction:column;text-align:center;gap:1.5rem}.photos-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}}@media(max-width:768px){.hero-section .hero-content h1{font-size:2.5rem}.hero-section .hero-content p{font-size:1.1rem}.login-buttons{gap:.75rem}.login-button{min-width:260px;padding:.875rem 1.5rem;font-size:1rem}.admin-panel h2,.photographer-panel h2,.welcome-header h2{font-size:2rem}.photos-header{flex-direction:column;align-items:flex-start}.photos-actions{width:100%;justify-content:space-between}.analytics-grid{grid-template-columns:1fr}.photos-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.modal-header{padding:1rem 1.5rem}.modal-content{padding:1.5rem}.toggle-option{flex-direction:column;align-items:flex-start;gap:.75rem}.training-control-section,.training-analytics,.photos-section,.upload-section{padding:1.5rem}}@media(max-width:480px){.hero-section .hero-content h1{font-size:2rem}.hero-section .hero-content p{font-size:1.1rem}.login-button{min-width:100%}.photos-grid{grid-template-columns:1fr}.analytics-grid{grid-template-columns:1fr;gap:1rem}.metric-card{padding:1.5rem}.view-my-photos-button{padding:1rem 2rem;font-size:1rem}}.hero-login-buttons{display:flex;gap:1rem;justify-content:center;align-items:center;margin-top:2rem;flex-wrap:wrap}.hero-logout-section{display:flex;justify-content:center;margin-top:2rem}.feature-highlights{display:flex;flex-direction:column;gap:1rem;margin-top:1.5rem}.feature-item{display:flex;align-items:center;padding:1rem;background:#6366f10d;border-radius:var(--border-radius-md);transition:all .3s ease}.feature-item:hover{background:#6366f11a;transform:translate(5px)}.active-trainings-list{display:flex;flex-direction:column;gap:1.5rem}.training-item{padding:1.5rem;background:linear-gradient(135deg,#6366f10d,#ec48990d);border-radius:var(--border-radius-lg);border:1px solid rgba(99,102,241,.1);transition:all .3s ease}.training-item:hover{transform:translateY(-2px);box-shadow:0 8px 20px #6366f126;border-color:#6366f14d}.training-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:.5rem}.training-event-name{font-size:1.125rem;font-weight:600;color:var(--color-primary-dark);margin:0}.training-status-badge{padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.training-status-badge.in_progress{background:linear-gradient(135deg,#6366f1,#ec4899);color:#fff}.training-status-badge.queued{background:#94a3b833;color:#64748b;border:1px solid rgba(148,163,184,.3)}.training-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:1rem}.training-stat{display:flex;flex-direction:column;gap:.25rem}.stat-label{font-size:.75rem;color:var(--color-gray-500);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.stat-value{font-size:1rem;color:var(--color-primary-dark);font-weight:600}@media(max-width:768px){.hero-login-buttons{flex-direction:column;width:100%;max-width:400px;margin-left:auto;margin-right:auto}.hero-login-buttons .hero-button{width:100%}.training-header{flex-direction:column;align-items:flex-start}.training-details{grid-template-columns:1fr 1fr}.feature-item{font-size:.9rem}}:root{--font-sans: -apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--font-serif: "New York", "Times New Roman", Times, serif;--font-mono: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, "Liberation Mono", monospace;--color-bg: #1e293b;--color-surface: #334155;--color-surface-hover: #475569;--color-border: rgba(255, 255, 255, .15);--color-text: #f8fafc;--color-text-dim: #cbd5e1;--color-primary: #38bdf8;--color-primary-dim: #0284c7;--color-accent: #818cf8;--color-warning: #fbbf24;--gradient-primary: linear-gradient(135deg, #38bdf8 0%, #818cf8 100%);--gradient-surface: linear-gradient(180deg, rgba(24, 24, 27, .8) 0%, rgba(24, 24, 27, .4) 100%);--gradient-glass: linear-gradient(180deg, rgba(255, 255, 255, .05) 0%, rgba(255, 255, 255, .02) 100%);--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-glow: 0 0 20px rgba(56, 189, 248, .15);--font-display: var(--font-sans);--color-background: var(--color-bg);--color-white: #FFFFFF;--header-height: 70px;--safe-top: env(safe-area-inset-top, 20px);--safe-bottom: env(safe-area-inset-bottom, 20px);--safe-left: env(safe-area-inset-left, 0px);--safe-right: env(safe-area-inset-right, 0px);--text-fluid-h1: clamp(2rem, 5vw + 1rem, 3.5rem);--text-fluid-h2: clamp(1.5rem, 3vw + 1rem, 2.5rem);--text-fluid-h3: clamp(1.25rem, 2vw + 1rem, 2rem);--text-fluid-body: clamp(.9rem, 1vw + .75rem, 1rem);--transition: .2s cubic-bezier(.4, 0, .2, 1);--transition-fast: .15s ease;--transition-bounce: cubic-bezier(.4, 0, .2, 1)}.min-h-dvh{min-height:100dvh}.h-dvh{height:100dvh}.safe-padding-bottom{padding-bottom:var(--safe-bottom)}.touch-target{min-height:44px;min-width:44px}*{margin:0;padding:0;box-sizing:border-box}body,html{margin:0;padding:0;width:100%;height:100%}body{font-family:var(--font-display);background:var(--color-bg);color:var(--color-text);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.global-nav-header{transition:all .3s ease;background:transparent!important;backdrop-filter:none!important;-webkit-backdrop-filter:none!important;border-bottom:none!important}.back-button-stagnant{transition:all .2s cubic-bezier(.4,0,.2,1)}.back-button-stagnant:hover{background-color:#ea580c!important;box-shadow:0 6px 16px #f9731640;transform:translateY(-1px)}.no-padding .global-nav-header{background:transparent!important;backdrop-filter:none!important;-webkit-backdrop-filter:none!important;border-bottom:none!important}.no-padding .back-button-stagnant{box-shadow:0 2px 4px #0000000d}.app{min-height:100dvh;display:flex;flex-direction:column;position:relative}.main-content{flex:1;margin-left:0;padding:2rem;padding-bottom:calc(2rem + var(--safe-bottom));max-width:100%;width:100%}.main-content.no-padding{padding:0}@media(min-width:1025px){.main-content{padding-top:2rem;margin-left:var(--sidebar-width);width:auto;transition:margin-left .3s cubic-bezier(.4,0,.2,1)}.main-content.no-padding{padding:0}}.main-content.full-width{max-width:100%;padding:0;width:100%!important;margin-left:0!important;background:#fff}.main-content.landing-mode{padding:0!important;max-width:100%!important;width:100%!important;flex:1!important;background:#fff!important;margin-left:0!important}@media(max-width:1024px){.main-content{margin-left:0;width:100%;padding:1rem}.sidebar{transform:translate(-100%)}.sidebar.mobile-open{transform:translate(0)}}.page-header{margin-bottom:3rem}.page-title{font-size:3rem;font-weight:800;margin-bottom:.5rem;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.03em;line-height:1.2}.page-description{font-size:1.125rem;color:var(--color-text-dim);max-width:600px}.card{background:var(--gradient-surface);border:1px solid var(--color-border);border-radius:16px;padding:2rem;box-shadow:var(--shadow-md);transition:all .3s ease;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:#00ff884d}.btn{padding:.75rem 1.75rem;border-radius:12px;font-weight:600;font-size:.95rem;font-family:var(--font-sans);text-transform:none;letter-spacing:.01em;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);border:1px solid transparent;display:inline-flex;align-items:center;gap:.5rem;text-decoration:none;justify-content:center}.btn-primary{background:var(--color-text);background:#fff;color:#09090b;box-shadow:0 4px 6px -1px #ffffff1a;border:1px solid #ffffff}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 10px 15px -3px #ffffff26;background:#f4f4f5}.btn-secondary{background:var(--color-surface);color:var(--color-text);border:2px solid var(--color-border)}.btn-secondary:hover{border-color:var(--color-primary);background:#00ff881a}.form-group{margin-bottom:1.5rem;display:flex;flex-direction:column;gap:.5rem}.form-label{font-weight:600;font-size:.9rem;color:var(--color-text);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.05em}.form-input,.form-select,.form-textarea{background:var(--color-bg);border:2px solid var(--color-border);border-radius:8px;padding:.875rem 1rem;color:var(--color-text);font-family:var(--font-display);font-size:1rem;transition:all .2s ease;outline:none;width:100%}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #00ff881a}.form-checkbox-group{display:flex;align-items:center;gap:.75rem;padding:1rem;background:var(--color-bg);border:2px solid var(--color-border);border-radius:8px;cursor:pointer;transition:all .2s ease}.form-checkbox-group:hover{border-color:var(--color-primary);background:#00ff880d}.grid{display:grid;gap:2rem}.grid-2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.grid-3{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.upload-zone{border:3px dashed var(--color-border);border-radius:16px;padding:3rem;text-align:center;cursor:pointer;transition:all .3s ease;background:var(--color-bg)}.upload-zone:hover,.upload-zone.drag-over{border-color:var(--color-primary);background:#00ff880d}.alert{padding:1rem 1.5rem;border-radius:8px;margin-bottom:1.5rem;display:flex;align-items:center;gap:.75rem;border-left:4px solid}.alert-success{background:#00ff881a;border-color:var(--color-primary);color:var(--color-primary)}.alert-warning{background:#ffaa001a;border-color:var(--color-warning);color:var(--color-warning)}.alert-error{background:#ff00661a;border-color:var(--color-accent);color:var(--color-accent)}.qr-display{background:#fff;padding:2rem;border-radius:12px;display:inline-block;box-shadow:var(--shadow-lg)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:var(--gradient-surface);border:1px solid var(--color-border);border-radius:12px;padding:1.5rem;text-align:center}.stat-value{font-size:2.5rem;font-weight:800;color:var(--color-primary);font-family:var(--font-mono)}.stat-label{font-size:.875rem;color:var(--color-text-dim);text-transform:uppercase;letter-spacing:.05em;font-weight:600;margin-top:.5rem}.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;margin-top:2rem}.feature-card{background:var(--gradient-surface);border:1px solid var(--color-border);border-radius:16px;padding:2rem;transition:all .3s ease;position:relative;overflow:hidden}.feature-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--gradient-primary);transform:scaleX(0);transition:transform .3s ease}.feature-card:hover:before{transform:scaleX(1)}.feature-card:hover{transform:translateY(-4px);border-color:#00ff884d;box-shadow:var(--shadow-lg)}.feature-icon{width:48px;height:48px;margin-bottom:1rem;color:var(--color-primary)}.feature-title{font-size:1.25rem;font-weight:700;margin-bottom:.75rem}.feature-description{color:var(--color-text-dim);line-height:1.6}.text-dim{color:var(--color-text-dim)}.text-primary{color:var(--color-primary)}.w-full{width:100%}.mt-4{margin-top:1rem}.mb-4{margin-bottom:1rem}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.page{animation:fadeInUp .5s ease}.hero{background:var(--color-bg)!important;position:relative;min-height:80vh;display:flex;align-items:center;overflow:hidden}.hero-backdrop{opacity:.4}.hero-title{color:var(--color-text);font-size:4rem;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-subtitle{color:var(--color-primary);font-family:var(--font-mono);margin-bottom:1.5rem}.hero-description{color:var(--color-text-dim);font-size:1.2rem}.hero-button.primary{background:var(--color-primary);color:var(--color-bg);border:none;font-weight:800;text-transform:uppercase;letter-spacing:.05em;padding:1rem 2rem;border-radius:4px}.hero-scroll-indicator{color:var(--color-primary)}.btn:disabled,.btn[disabled]{opacity:.5;cursor:not-allowed;transform:none!important;box-shadow:none!important}.btn:disabled:hover{transform:none!important}.loading{display:inline-block;width:20px;height:20px;border:2px solid var(--color-border);border-radius:50%;border-top-color:var(--color-primary);animation:spin .8s linear infinite}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #00ff8826,0 0 20px #00ff881a;outline:none}.form-input::placeholder{color:var(--color-text-dim);opacity:.6}.card-glass{background:#16161dcc;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1)}.card,.btn,.feature-card,.stat-card{transition:all .3s cubic-bezier(.4,0,.2,1)}::selection{background:#00ff884d;color:var(--color-text)}a:not(.btn):not(.sidebar-nav-link){position:relative;transition:color .2s ease}a:not(.btn):not(.sidebar-nav-link):hover{color:var(--color-primary)}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}@media(max-width:768px){.btn{min-height:44px;padding:.75rem 1.5rem}.sidebar-nav-link{min-height:48px}}@keyframes pulse-glow{0%,to{box-shadow:0 0 5px #0f86}50%{box-shadow:0 0 20px #0f89,0 0 30px #00ff884d}}.pulse-active{animation:pulse-glow 2s ease-in-out infinite}.skeleton{background:linear-gradient(90deg,var(--color-surface) 25%,var(--color-surface-hover) 50%,var(--color-surface) 75%);background-size:200% 100%;animation:skeleton-loading 1.5s ease-in-out infinite;border-radius:4px}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.badge{display:inline-flex;align-items:center;padding:.25rem .75rem;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;border-radius:4px;font-family:var(--font-mono)}.badge-primary{background:#00ff8826;color:var(--color-primary);border:1px solid rgba(0,255,136,.3)}.badge-warning{background:#ffaa0026;color:var(--color-warning);border:1px solid rgba(255,170,0,.3)}.badge-accent{background:#ff006626;color:var(--color-accent);border:1px solid rgba(255,0,102,.3)}[data-tooltip]{position:relative}[data-tooltip]:after{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translate(-50%) translateY(-8px);padding:.5rem .75rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:6px;font-size:.75rem;white-space:nowrap;opacity:0;visibility:hidden;transition:all .2s ease;z-index:1000;box-shadow:var(--shadow-md)}[data-tooltip]:hover:after{opacity:1;visibility:visible;transform:translate(-50%) translateY(-4px)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;color:var(--color-text-dim)}.empty-state-icon{width:64px;height:64px;margin-bottom:1.5rem;opacity:.5}.empty-state-title{font-size:1.25rem;font-weight:700;color:var(--color-text);margin-bottom:.5rem}.empty-state-description{font-size:.9rem;max-width:400px}.divider{height:1px;background:linear-gradient(90deg,transparent,var(--color-border),transparent);margin:2rem 0}.hide-scrollbar{-ms-overflow-style:none;scrollbar-width:none}.hide-scrollbar::-webkit-scrollbar{display:none}table{width:100%;border-collapse:collapse}th,td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--color-border)}th{font-weight:600;color:var(--color-text-dim);font-size:.8rem;text-transform:uppercase;letter-spacing:.05em}tr:hover td{background:#00ff8808}@media(max-width:768px){.page-title{font-size:2rem}.page-description{font-size:1rem}.stat-value{font-size:1.75rem}}.sidebar-toggle{display:none!important}@media(max-width:1024px){.sidebar-toggle{display:block!important}}.photographer-event-grid{display:grid;grid-template-columns:1fr;gap:2rem;align-items:start}@media(min-width:1024px){.photographer-event-grid{grid-template-columns:minmax(320px,1fr) 2fr}}.dashboard-container{display:grid;grid-template-columns:1fr;gap:1.25rem;max-width:1600px;margin:0 auto;height:100%}@media(min-width:1024px){.dashboard-container{grid-template-columns:3fr 1fr}}.dashboard-metrics-grid{display:grid;grid-template-columns:1fr;gap:1rem}@media(min-width:640px){.dashboard-metrics-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.dashboard-metrics-grid{grid-template-columns:repeat(3,1fr)}}.dashboard-actions-grid{display:grid;grid-template-columns:1fr;gap:1rem}@media(min-width:640px){.dashboard-actions-grid{grid-template-columns:1fr 1fr}}.collage-main-content{flex-direction:column-reverse}.collage-sidebar{width:100%;max-height:250px;border-top:1px solid #E2E8F0;border-right:none}@media(min-width:768px){.collage-main-content{flex-direction:row}.collage-sidebar{width:320px;max-height:none;border-right:1px solid #E2E8F0;border-top:none}}.overflow-x-auto{overflow-x:auto;-webkit-overflow-scrolling:touch}.event-payment-grid{display:grid;grid-template-columns:1fr}.billing-name-grid,.billing-address-grid{display:grid;grid-template-columns:1fr;gap:1rem}@media(min-width:640px){.billing-name-grid{grid-template-columns:1fr 1fr}.billing-address-grid{grid-template-columns:1fr 1fr 1fr}}@media(min-width:900px){.event-payment-grid{grid-template-columns:minmax(300px,1fr) 1.5fr}}.hide-on-mobile{display:none}.header-action-btn{padding:.4rem .75rem!important;font-size:.75rem!important;white-space:nowrap}@media(min-width:640px){.hide-on-mobile{display:inline}.header-action-btn{padding:.5rem 1rem!important;font-size:.85rem!important}}.filter-tab-btn{padding:.25rem .5rem;font-size:.7rem}@media(min-width:640px){.filter-tab-btn{padding:.35rem .85rem;font-size:.8rem}}body{background:var(--color-bg)!important;background-attachment:fixed!important}.app{background:transparent!important}.app main,.main-content{margin-left:var(--sidebar-width)!important;width:calc(100% - var(--sidebar-width))!important;display:flex!important;flex-direction:column!important;background:transparent!important}.sidebar.collapsed~main,.sidebar.collapsed~.main-content{margin-left:80px!important;width:calc(100% - 80px)!important}.container{display:flex!important;flex-direction:column!important;align-items:center!important;max-width:1280px!important;width:100%!important;margin:0 auto!important;padding:0 2rem!important}.hero{background:var(--color-bg)!important;display:flex!important;flex-direction:column!important;align-items:center!important;justify-content:center!important;padding:4rem 0!important;min-height:70vh!important;position:relative!important;overflow:hidden!important}.hero:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 30%,rgba(0,255,136,.05) 0%,transparent 50%),radial-gradient(circle at 80% 70%,rgba(0,204,255,.05) 0%,transparent 50%);pointer-events:none;z-index:0}.hero>*{position:relative;z-index:1}.hero-backdrop{display:none!important}.hero .container{display:flex!important;flex-direction:column!important;align-items:center!important;justify-content:center!important;max-width:900px!important;width:100%!important;padding:0 2rem!important;margin:0 auto!important;text-align:center!important}.hero-content{display:flex!important;flex-direction:column!important;align-items:center!important;justify-content:center!important;text-align:center!important;width:100%!important;max-width:900px!important;margin:0 auto!important}.hero-left{display:flex!important;flex-direction:column!important;align-items:center!important;text-align:center!important;max-width:100%!important;width:100%!important}.hero-right,.hero-visual{display:none!important}.hero-title{text-align:center!important;color:var(--color-text)!important;margin-bottom:1.5rem!important;width:100%!important;background:var(--gradient-primary)!important;-webkit-background-clip:text!important;-webkit-text-fill-color:transparent!important;background-clip:text!important}.hero-subtitle{text-align:center!important;color:var(--color-primary)!important;margin-bottom:1rem!important;width:100%!important;font-family:var(--font-mono)!important}.hero-description{text-align:center!important;color:var(--color-text-dim)!important;margin-bottom:2rem!important;width:100%!important;max-width:700px!important;margin-left:auto!important;margin-right:auto!important}.hero-buttons{display:flex!important;justify-content:center!important;align-items:center!important;gap:1rem!important;flex-wrap:wrap!important;width:100%!important}.hero-button{box-shadow:0 4px 14px #00ff8826!important;transition:all .3s ease!important}.hero-button:hover{box-shadow:0 6px 20px #00ff8840!important;transform:translateY(-2px)!important}.hero-button.primary{background:var(--gradient-primary)!important;color:var(--color-bg)!important}.hero-button.secondary{background:var(--color-surface)!important;color:var(--color-text)!important;border:2px solid var(--color-border)!important}.hero-button.secondary:hover{border-color:var(--color-primary)!important;background:#00ff881a!important}.section-title{text-align:center!important;color:var(--color-text)!important}.section-subtitle{text-align:center!important;color:var(--color-text-dim)!important}.system-section{padding:2rem 0!important;display:flex!important;flex-direction:column!important;align-items:center!important;background:transparent!important;position:relative!important;width:100%!important}.system-section .container{display:flex!important;flex-direction:column!important;align-items:center!important;max-width:1200px!important;width:100%!important;padding:0 2rem!important;margin:0 auto!important}.system-page{background:var(--color-bg)!important}.system-card{background:var(--gradient-surface)!important;-webkit-backdrop-filter:blur(20px)!important;backdrop-filter:blur(20px)!important;border:1px solid var(--color-border)!important;box-shadow:var(--shadow-md)!important;color:var(--color-text)!important;border-radius:16px!important}.system-card:hover{box-shadow:var(--shadow-lg)!important;transform:translateY(-4px)!important;border-color:#00ff884d!important}.system-card .card-title{color:var(--color-text)!important;font-size:1.5rem!important;font-weight:700!important}.system-card .card-text{color:var(--color-text-dim)!important;line-height:1.8!important}.component-item{background:var(--color-surface)!important;-webkit-backdrop-filter:blur(15px)!important;backdrop-filter:blur(15px)!important;border:1px solid var(--color-border)!important;color:var(--color-text)!important;box-shadow:var(--shadow-sm)!important;border-radius:10px!important;padding:1.5rem!important;transition:all .3s ease!important}.component-item:hover{box-shadow:var(--shadow-md)!important;transform:translateY(-2px) scale(1.01)!important;border-color:#00ff8840!important}.component-title{color:var(--color-text)!important;font-weight:700!important;font-size:1.125rem!important}.component-description{color:var(--color-text-dim)!important;line-height:1.7!important}.features-section{display:flex!important;flex-direction:column!important;align-items:center!important;background:transparent!important;position:relative!important}.features-grid{justify-content:center!important}.feature-card{transition:all .3s ease!important;background:var(--gradient-surface)!important;border:1px solid var(--color-border)!important}.feature-card:hover{box-shadow:var(--shadow-lg)!important;border-color:#0f83!important}.folder-card{background:var(--color-surface)!important;border:1px solid var(--color-border)!important;color:var(--color-text)!important;box-shadow:var(--shadow-md)!important;border-radius:12px!important}.folder-card:hover{box-shadow:var(--shadow-lg)!important;border-color:#00ff884d!important}.folder-name{color:var(--color-text)!important;font-weight:700!important}.folder-metadata{color:var(--color-text-dim)!important}.modal-overlay{background:#000000b3!important;-webkit-backdrop-filter:blur(8px)!important;backdrop-filter:blur(8px)!important}.modal-content{background:var(--color-surface)!important;-webkit-backdrop-filter:blur(20px)!important;backdrop-filter:blur(20px)!important;border:1px solid var(--color-border)!important;color:var(--color-text)!important;box-shadow:var(--shadow-lg)!important;border-radius:16px!important}.modal-title{color:var(--color-text)!important}.modal-text{color:var(--color-text-dim)!important}.training-control-section,.training-analytics,.photos-section{background:var(--color-surface)!important;-webkit-backdrop-filter:blur(10px)!important;backdrop-filter:blur(10px)!important;padding:2rem!important;border-radius:16px!important;box-shadow:var(--shadow-md)!important;margin-bottom:2rem!important;border:1px solid var(--color-border)!important;transition:all .3s ease!important}.training-control-section:before,.training-analytics:before,.photos-section:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-primary);opacity:0;transition:opacity .3s ease}.training-control-section:hover,.training-analytics:hover{transform:translateY(-4px)!important;box-shadow:var(--shadow-lg)!important}.training-control-section:hover:before,.training-analytics:hover:before,.photos-section:hover:before{opacity:1}.metric-card{padding:1.75rem!important;background:var(--color-bg)!important;-webkit-backdrop-filter:blur(10px)!important;backdrop-filter:blur(10px)!important;border-radius:12px!important;text-align:center!important;border:1px solid var(--color-border)!important;transition:all .3s ease!important}.metric-card:hover{transform:translateY(-4px) scale(1.02)!important;box-shadow:var(--shadow-md)!important;border-color:#00ff884d!important}.metric-title{font-size:.875rem!important;font-weight:600!important;color:var(--color-text-dim)!important;text-transform:uppercase!important;letter-spacing:.05em!important;margin-bottom:.75rem!important}.metric-value{font-size:2rem!important;font-weight:700!important;color:var(--color-primary)!important}.progress-bar{width:100%!important;height:8px!important;background:var(--color-bg)!important;border-radius:4px!important;margin-top:1rem!important;overflow:hidden!important}.progress{height:100%!important;background:var(--gradient-primary)!important;transition:width .5s ease!important;border-radius:4px!important;box-shadow:0 0 10px #00ff8880!important}footer{background:var(--color-surface)!important;color:var(--color-text)!important;padding:3rem 0 1.5rem!important;margin-top:4rem!important;border-top:1px solid var(--color-border)!important;position:relative!important;overflow:hidden!important}.footer-logo-text{color:var(--color-primary)!important}.footer-link{color:var(--color-text-dim)!important}.footer-link:hover{color:var(--color-primary)!important}.copyright,.attribution{color:var(--color-text-dim)!important}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-primary-dim)}@media(max-width:1024px){.sidebar{transform:translate(-100%)!important}.sidebar.mobile-open{transform:translate(0)!important}.app main,.main-content{margin-left:0!important;width:100%!important;padding:1rem!important}.sidebar-toggle{display:flex!important}}@media(max-width:480px){.app main,.main-content{padding:.5rem!important}.page-title{font-size:2rem!important}}@keyframes glow{0%,to{box-shadow:0 0 5px #00ff8880}50%{box-shadow:0 0 20px #0f8c}}.model-showcase-section{padding:5rem 0!important;position:relative!important;overflow:hidden!important;background:var(--color-bg)!important}.model-showcase-section:before{content:""!important;position:absolute!important;inset:0!important;background:radial-gradient(circle at 25% 25%,rgba(0,255,136,.03) 0%,transparent 60%),radial-gradient(circle at 75% 75%,rgba(0,204,255,.03) 0%,transparent 60%)!important;pointer-events:none!important;z-index:0!important}.model-showcase-section>*{position:relative!important;z-index:1!important}.section-header{text-align:center!important;max-width:800px!important;margin:0 auto 3rem!important}.model-cards-container{display:flex!important;flex-wrap:wrap!important;gap:1.5rem!important;justify-content:center!important;margin-bottom:3rem!important}.model-card{background:var(--color-surface)!important;border:1px solid var(--color-border)!important;border-radius:12px!important;padding:1.75rem!important;width:calc(33.333% - 1rem)!important;box-shadow:var(--shadow-md)!important;cursor:pointer!important;transition:all .3s ease!important;position:relative!important}.model-card:hover{transform:translateY(-5px)!important;box-shadow:var(--shadow-lg)!important;border-color:#00ff884d!important}.model-card.active{border-color:var(--color-primary)!important;box-shadow:0 15px 30px #00ff8826,0 0 20px #00ff881a!important}.model-card.active:before{content:""!important;position:absolute!important;top:0!important;left:0!important;right:0!important;height:4px!important;background:var(--gradient-primary)!important;border-radius:12px 12px 0 0!important}.model-card-header{margin-bottom:1rem!important}.model-card-header h3{font-size:1.25rem!important;font-weight:600!important;color:var(--color-text)!important;margin-bottom:.25rem!important}.model-category{display:inline-block!important;padding:.35rem .75rem!important;background:#00ff881a!important;border-radius:20px!important;color:var(--color-primary)!important;font-size:.75rem!important;font-weight:600!important}.model-metrics{display:flex!important;gap:1.5rem!important;margin-bottom:1.5rem!important}.metric{display:flex!important;flex-direction:column!important}.metric-label{font-size:.75rem!important;color:var(--color-text-dim)!important;margin-bottom:.25rem!important}.metric-value{font-size:1.5rem!important;font-weight:700!important;color:var(--color-primary)!important}.model-tech-badge{display:inline-block!important;padding:.5rem .75rem!important;background:#00ccff1a!important;border:1px solid rgba(0,204,255,.2)!important;border-radius:6px!important;color:#0cf!important;font-size:.75rem!important;font-weight:600!important;letter-spacing:.02em!important}.model-details{background:var(--color-surface)!important;border:1px solid var(--color-border)!important;border-radius:16px!important;padding:2.5rem!important;box-shadow:var(--shadow-lg)!important;margin-bottom:3rem!important;overflow:hidden!important}.model-info-container{display:grid!important;grid-template-columns:1fr 1fr!important;gap:3rem!important;margin-bottom:2.5rem!important}.model-info h3{font-size:1.75rem!important;font-weight:700!important;color:var(--color-text)!important;margin-bottom:1rem!important}.model-description{font-size:1.0625rem!important;line-height:1.7!important;color:var(--color-text-dim)!important;margin-bottom:1.5rem!important}.model-info h4{font-size:1.125rem!important;font-weight:600!important;color:var(--color-text)!important;margin-bottom:1rem!important}.model-features{list-style-type:none!important;padding:0!important;display:grid!important;grid-template-columns:1fr 1fr!important;gap:.75rem 1rem!important}.model-features li{display:flex!important;align-items:center!important;font-size:.9375rem!important;color:var(--color-text-dim)!important}.feature-icon{color:var(--color-primary)!important;margin-right:.5rem!important;flex-shrink:0!important}.model-visual{position:relative!important}.model-demo{border-radius:12px!important;overflow:hidden!important;box-shadow:var(--shadow-lg)!important}.demo-image-container{width:100%!important;aspect-ratio:16 / 9!important;background-color:var(--color-bg)!important;position:relative!important}.demo-overlay{position:absolute!important;inset:0!important;display:flex!important;flex-direction:column!important;justify-content:center!important;align-items:center!important}.processing-indicator{position:absolute!important;bottom:1rem!important;right:1rem!important;display:flex!important;gap:4px!important}.processing-box{width:10px!important;height:10px!important;background-color:var(--color-primary)!important;border-radius:2px!important;animation:pulse 1.5s infinite ease-in-out!important}.box1{animation-delay:0s!important}.box2{animation-delay:.2s!important}.box3{animation-delay:.4s!important}.box4{animation-delay:.6s!important}@keyframes pulse{0%,to{transform:scale(1);opacity:.5}50%{transform:scale(1.2);opacity:1}}.detection-box{position:absolute!important;border:2px solid var(--color-primary)!important;border-radius:4px!important;padding:4px 8px!important;font-size:.75rem!important;font-weight:600!important;color:var(--color-bg)!important;background-color:#0f8c!important;display:flex!important;justify-content:space-between!important;align-items:center!important;gap:.5rem!important}.helmet{top:20%!important;left:15%!important}.vest{top:50%!important;left:25%!important}.goggles{top:35%!important;left:35%!important}.confidence{font-size:.675rem!important;opacity:.9!important;font-weight:400!important}.cluster-group{position:absolute!important;border:2px solid #00ccff!important;border-radius:4px!important;padding:4px 8px!important;font-size:.75rem!important;font-weight:600!important;color:var(--color-bg)!important;background-color:#0cfc!important}.group1{top:25%!important;left:20%!important}.group2{top:40%!important;left:45%!important}.group3{top:60%!important;left:30%!important}.recognition-box{position:absolute!important;border:2px solid var(--color-primary)!important;border-radius:4px!important;padding:4px 8px!important;font-size:.75rem!important;font-weight:600!important;color:var(--color-bg)!important;background-color:#0f8c!important;display:flex!important;justify-content:space-between!important;align-items:center!important;gap:.5rem!important}.person1{top:35%!important;left:25%!important}.recognition-indicator{position:absolute!important;bottom:20%!important;right:20%!important;display:flex!important;flex-direction:column!important;align-items:center!important;gap:.5rem!important}.liveness{background-color:var(--color-primary)!important;color:var(--color-bg)!important;font-size:.75rem!important;font-weight:600!important;padding:4px 12px!important;border-radius:20px!important;box-shadow:0 2px 8px #0f86!important;animation:fade-in 1s ease-out!important}@keyframes fade-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.demo-caption{background-color:var(--color-bg)!important;color:var(--color-text)!important;padding:.75rem 1rem!important;font-size:.875rem!important;display:flex!important;justify-content:space-between!important;align-items:center!important}.ai-badge{background-color:#0f83!important;color:var(--color-primary)!important;padding:.25rem .5rem!important;font-size:.75rem!important;font-weight:600!important;border-radius:4px!important;display:inline-flex!important;align-items:center!important}.tech-specs{background-color:var(--color-bg)!important;border-radius:12px!important;padding:1.5rem!important;margin-bottom:2.5rem!important;border:1px solid var(--color-border)!important}.tech-specs h4{font-size:1.125rem!important;font-weight:600!important;color:var(--color-text)!important;margin-bottom:1.5rem!important;padding-left:.5rem!important;border-left:3px solid var(--color-primary)!important}.specs-grid{display:grid!important;grid-template-columns:repeat(3,1fr)!important;gap:1.5rem!important}.spec-item{display:flex!important;flex-direction:column!important;gap:.25rem!important}.spec-name{font-size:.75rem!important;color:var(--color-text-dim)!important;font-weight:500!important}.spec-value{font-size:.9375rem!important;color:var(--color-text)!important;font-weight:600!important}.model-cta{display:flex!important;gap:1rem!important;justify-content:center!important}.model-explore-btn,.model-demo-btn{min-width:180px!important}@media screen and (max-width:1024px){.model-card{width:calc(50% - .75rem)!important}.model-info-container{grid-template-columns:1fr!important;gap:2rem!important}.specs-grid{grid-template-columns:repeat(2,1fr)!important}}@media screen and (max-width:768px){.model-cards-container{flex-direction:column!important;max-width:500px!important;margin:0 auto 2rem!important}.model-card{width:100%!important}.model-features{grid-template-columns:1fr!important}.specs-grid{grid-template-columns:1fr!important;gap:1rem!important}.model-cta{flex-direction:column!important}}@media screen and (max-width:480px){.model-details{padding:1.5rem!important}.demo-caption{flex-direction:column!important;gap:.5rem!important;align-items:flex-start!important}}.demo-image-container{position:relative!important}.demo-image-container:before{content:""!important;position:absolute!important;top:0!important;left:0!important;width:100%!important;height:100%!important;background:linear-gradient(135deg,var(--color-bg) 0%,var(--color-surface) 100%)!important;display:flex!important;justify-content:center!important;align-items:center!important;color:var(--color-primary)!important;z-index:0!important}.demo-image-container[data-model=safety]:before{background:linear-gradient(135deg,var(--color-surface) 0%,var(--color-bg) 100%),url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="%2300ff88" stroke-width="1" stroke-linecap="round" stroke-linejoin="round"><path d="M12 22s8-4 8-10V5l-8-3-8 3v7c0 6 8 10 8 10z"></path></svg>')!important;background-size:cover,80px!important;background-position:center,center!important;background-repeat:no-repeat!important}.demo-image-container[data-model=face-clustering]:before{background:linear-gradient(135deg,var(--color-surface) 0%,var(--color-bg) 100%),url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="%2300ff88" stroke-width="1" stroke-linecap="round" stroke-linejoin="round"><rect x="2" y="2" width="20" height="8" rx="2" ry="2"></rect><rect x="2" y="14" width="20" height="8" rx="2" ry="2"></rect><line x1="6" y1="6" x2="6.01" y2="6"></line><line x1="6" y1="18" x2="6.01" y2="18"></line></svg>')!important;background-size:cover,80px!important;background-position:center,center!important;background-repeat:no-repeat!important}.demo-image-container[data-model=face-recognition]:before{background:linear-gradient(135deg,var(--color-surface) 0%,var(--color-bg) 100%),url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="%2300ff88" stroke-width="1" stroke-linecap="round" stroke-linejoin="round"><circle cx="12" cy="8" r="7"></circle><polyline points="8.21 13.89 7 23 12 20 17 23 15.79 13.88"></polyline></svg>')!important;background-size:cover,80px!important;background-position:center,center!important;background-repeat:no-repeat!important}.model-grid-section{padding:5rem 0!important;position:relative!important;overflow:hidden!important;background:var(--color-bg)!important}.model-grid-section:before{content:""!important;position:absolute!important;inset:0!important;background:radial-gradient(circle at 25% 25%,rgba(0,255,136,.03) 0%,transparent 60%),radial-gradient(circle at 75% 75%,rgba(0,204,255,.03) 0%,transparent 60%)!important;pointer-events:none!important;z-index:0!important}.model-grid-section>*{position:relative!important;z-index:1!important}.model-controls{display:flex!important;flex-direction:column!important;gap:1.5rem!important;margin-bottom:2rem!important}.model-filters{display:flex!important;flex-wrap:wrap!important;gap:.75rem!important;justify-content:center!important}.filter-button{background:var(--color-surface)!important;border:1px solid var(--color-border)!important;border-radius:50px!important;padding:.5rem 1.25rem!important;font-size:.875rem!important;font-weight:500!important;color:var(--color-text-dim)!important;cursor:pointer!important;transition:all .2s ease!important}.filter-button:hover{border-color:var(--color-primary)!important;background:#00ff880d!important;color:var(--color-primary)!important}.filter-button.active{background:var(--color-primary)!important;border-color:var(--color-primary)!important;color:var(--color-bg)!important;box-shadow:0 2px 8px #00ff884d!important}.model-search{position:relative!important;max-width:600px!important;margin:0 auto!important;width:100%!important}.model-search input{width:100%!important;padding:.75rem 1.25rem!important;font-size:1rem!important;border:1px solid var(--color-border)!important;border-radius:8px!important;background:var(--color-surface)!important;color:var(--color-text)!important;box-shadow:var(--shadow-sm)!important;transition:all .2s ease!important}.model-search input:focus{outline:none!important;border-color:var(--color-primary)!important;box-shadow:0 0 0 3px #00ff8826!important}.model-search input::placeholder{color:var(--color-text-dim)!important}.clear-search{position:absolute!important;right:1rem!important;top:50%!important;transform:translateY(-50%)!important;background:none!important;border:none!important;color:var(--color-text-dim)!important;font-size:1.25rem!important;line-height:1!important;padding:.25rem!important;cursor:pointer!important;transition:color .2s ease!important}.clear-search:hover{color:var(--color-text)!important}.results-info{text-align:center!important;font-size:.875rem!important;color:var(--color-text-dim)!important;margin-bottom:2rem!important}.models-grid{display:grid!important;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))!important;gap:1.5rem!important}.model-card{background:var(--color-surface)!important;border:1px solid var(--color-border)!important;border-radius:12px!important;padding:1.5rem!important;box-shadow:var(--shadow-md)!important;transition:all .3s ease!important;cursor:pointer!important;position:relative!important;overflow:hidden!important}.model-card:hover{transform:translateY(-4px)!important;box-shadow:var(--shadow-lg)!important;border-color:#00ff884d!important}.model-header{display:flex!important;justify-content:space-between!important;align-items:flex-start!important;margin-bottom:1rem!important;gap:1rem!important}.model-header h3{font-size:1.125rem!important;font-weight:600!important;color:var(--color-text)!important;margin:0!important}.model-category-badge{display:inline-block!important;padding:.25rem .5rem!important;background:#00ff881a!important;color:var(--color-primary)!important;font-size:.6875rem!important;font-weight:600!important;border-radius:4px!important;white-space:nowrap!important}.model-metrics{display:flex!important;gap:1rem!important;margin-bottom:1rem!important}.model-metric{background:var(--color-bg)!important;padding:.5rem .75rem!important;border-radius:6px!important;flex:1!important;border:1px solid var(--color-border)!important}.metric-label{display:block!important;font-size:.6875rem!important;color:var(--color-text-dim)!important;margin-bottom:.25rem!important}.metric-value{font-size:.875rem!important;font-weight:600!important;color:var(--color-primary)!important}.model-description{font-size:.875rem!important;line-height:1.5!important;color:var(--color-text-dim)!important;margin-bottom:1.25rem!important;display:-webkit-box!important;-webkit-box-orient:vertical!important;-webkit-line-clamp:3!important;overflow:hidden!important}.model-tags{display:flex!important;flex-wrap:wrap!important;gap:.5rem!important;margin-bottom:1.25rem!important}.model-tag{font-size:.6875rem!important;padding:.25rem .5rem!important;background:#00ccff1a!important;color:#0cf!important;border-radius:4px!important;font-weight:500!important}.model-frameworks{display:flex!important;flex-wrap:wrap!important;gap:.5rem!important;margin-bottom:1.25rem!important}.model-framework{font-size:.6875rem!important;padding:.25rem .5rem!important;background:#ffaa001a!important;color:var(--color-warning)!important;border-radius:4px!important;font-weight:500!important}.model-card-actions{display:flex!important;justify-content:center!important}.model-detail-button{background:none!important;border:1px solid var(--color-primary)!important;color:var(--color-primary)!important;padding:.375rem .75rem!important;font-size:.75rem!important;font-weight:500!important;border-radius:4px!important;cursor:pointer!important;transition:all .2s ease!important}.model-detail-button:hover{background:#00ff881a!important}.model-details-expanded{margin-top:1.25rem!important;padding-top:1.25rem!important;border-top:1px solid var(--color-border)!important;overflow:hidden!important}.model-details-expanded h4{font-size:1rem!important;font-weight:600!important;color:var(--color-text)!important;margin:0 0 .75rem!important}.model-details-expanded ul{list-style:none!important;padding:0!important;margin:0 0 1.25rem!important}.model-details-expanded li{font-size:.875rem!important;color:var(--color-text-dim)!important;margin-bottom:.5rem!important;display:flex!important;align-items:center!important}.model-details-expanded li:before{content:"•"!important;color:var(--color-primary)!important;margin-right:.5rem!important}.model-detail-actions{display:flex!important;gap:.75rem!important;justify-content:flex-start!important}.model-detail-actions button{font-size:.75rem!important;padding:.375rem .75rem!important}.no-results{display:flex!important;flex-direction:column!important;align-items:center!important;justify-content:center!important;padding:4rem!important;text-align:center!important}.no-results svg{color:var(--color-text-dim)!important;margin-bottom:1rem!important}.no-results p{color:var(--color-text-dim)!important;font-size:1.125rem!important;margin-bottom:1.5rem!important}@media screen and (max-width:768px){.model-filters{justify-content:flex-start!important;overflow-x:auto!important;padding-bottom:.5rem!important;margin:0 -1rem!important;padding:0 1rem .5rem!important}.models-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))!important}}@media screen and (max-width:480px){.model-metrics{flex-direction:column!important;gap:.5rem!important}.models-grid{grid-template-columns:1fr!important}.model-detail-actions{flex-direction:column!important;width:100%!important}.model-detail-actions button{width:100%!important}}.photo-landing{--orange: #f5821f;--orange-dark: #df6f12;--ink: #232323;--muted: #666;--light: #f2f2f2;--white: #fff;font-family:Nunito,sans-serif;color:var(--ink);background:var(--light);min-height:100vh;display:flex;flex-direction:column}.photo-landing *{box-sizing:border-box}.photo-landing .section{padding:56px 22px}.photo-landing .section-title{font-family:Sora,sans-serif;color:var(--orange)!important;text-align:center;font-size:clamp(1.8rem,5vw,2.8rem);margin:0 auto 30px;font-weight:700;max-width:900px}.photo-landing .section-title.white{color:var(--white)!important}.photo-landing .landing-hero{position:relative;min-height:100vh;display:flex;flex-direction:column;background-size:cover;background-position:center top;background-repeat:no-repeat;color:#fff;overflow:hidden}.photo-landing .landing-hero-overlay{position:absolute;inset:0;background:#ffb45059}.photo-landing .landing-hero-header{position:relative;z-index:10;max-width:1700px;width:100%;margin:0 auto;padding:24px 48px;display:flex;align-items:center;justify-content:space-between}.photo-landing .brand-logo-img{max-height:48px;width:auto;object-fit:contain}.photo-landing .landing-hero-nav{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:32px;margin-left:auto}.photo-landing .mobile-nav-toggle{display:none;background:transparent;border:none;color:#fff;cursor:pointer;z-index:1000}.photo-landing .landing-hero-nav a{color:#fffffff5;text-decoration:none;font-size:1.4rem;font-weight:800;letter-spacing:.02em;text-shadow:0 1px 8px rgba(0,0,0,.22)}.photo-landing .landing-hero-content{position:relative;z-index:2;max-width:100%;align-self:stretch;margin:auto 0 0;padding:80px 48px 60px;display:flex;flex-direction:column;justify-content:center}.photo-landing .landing-hero-content h1{max-width:1200px;margin:0;font-family:Sora,sans-serif;font-size:4.5rem;line-height:1.1;color:#fff;font-weight:800;text-shadow:0 2px 15px rgba(0,0,0,.3)}.photo-landing .landing-hero-content p{max-width:800px;margin:20px 0 30px;font-size:1.5rem;line-height:1.4;color:#fff;font-weight:600;text-shadow:0 1px 10px rgba(0,0,0,.25)}.photo-landing .landing-hero-bottom-row{max-width:none;width:100%;margin-top:10px;display:flex;align-items:center;justify-content:space-between;gap:22px;flex-wrap:wrap}.photo-landing .cta-primary{border:none;background:var(--orange);color:#fff;border-radius:999px;padding:9px 18px;font-weight:700;font-size:1rem;cursor:pointer;transition:background .2s ease,transform .2s ease}.photo-landing .cta-primary:hover{background:var(--orange-dark);transform:translateY(-1px)}.photo-landing .landing-hero .cta-primary{border:2px solid #ffffff;border-radius:50px;padding:12px 32px;font-size:1.15rem;background:var(--orange);color:#fff;box-shadow:0 4px 10px #0003;transition:background .2s ease,transform .2s ease,box-shadow .2s ease}.photo-landing .landing-hero .cta-primary:hover{background:var(--orange-dark);transform:translateY(-1px);box-shadow:0 8px 18px #0000003d}.photo-landing .landing-hero-socials{display:flex;gap:16px}.photo-landing .landing-hero-socials a,.photo-landing .landing-hero-socials>*{display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:#000;padding:4px}.photo-landing .landing-hero-socials svg{color:#000;width:48px;height:48px;stroke-width:2}.photo-landing .section-light{background:var(--light)}.photo-landing .scale-grid{max-width:1120px;margin:0 auto;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:34px 28px}.photo-landing .scale-card{text-align:center;background:transparent}.photo-landing .scale-card h3{margin:10px 0 8px;font-size:2.2rem;line-height:1.15}.photo-landing .scale-card p{margin:0;color:var(--muted);font-size:1.15rem;line-height:1.35}.photo-landing .scale-icon{color:var(--orange);width:42px;height:42px}.photo-landing .action-row{max-width:1120px;margin:42px auto 40px;display:flex;gap:16px;flex-wrap:wrap;justify-content:center}.photo-landing .action-row .action-btn{border:1.5px solid var(--orange);color:var(--orange-dark);background:#fff;border-radius:999px;padding:9px 18px;display:inline-flex;align-items:center;gap:9px;font-weight:700;font-size:1.05rem;transition:transform .2s ease,box-shadow .2s ease}.photo-landing .action-row .action-btn svg{width:18px;height:18px}.photo-landing .action-row .action-btn:hover{transform:translateY(-1px);box-shadow:0 8px 16px #00000014}.photo-landing .action-row .action-btn-create{background:var(--orange);color:#fff;border-color:var(--orange)}.photo-landing .setup-grid{max-width:1120px;margin:14px auto 0;display:grid;grid-template-columns:1.1fr 1fr;gap:24px}.photo-landing .setup-image-box img{width:100%;max-width:560px;aspect-ratio:4 / 3;height:auto;object-fit:cover;border-radius:14px}.photo-landing .setup-image-box h3{margin:14px 0 6px;font-family:Sora,sans-serif;font-size:3rem;line-height:1.08}.photo-landing .setup-image-box p{margin:0;color:var(--muted);font-size:1.35rem;line-height:1.35}.photo-landing .event-form{position:relative;border:2px dashed rgba(245,130,31,.4);border-radius:12px;background:#f7f7f7;padding:20px;display:grid;gap:12px}.photo-landing .event-form-inner{position:relative;width:100%;display:grid;gap:12px}.photo-landing .form-login-hint{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#f5821f;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;padding:24px;border-radius:16px;font-size:1rem;font-weight:700;text-align:center;box-shadow:0 20px 40px #0000004d;z-index:100;width:100%;pointer-events:none;border:1px solid rgba(255,255,255,.3);line-height:1.5}.photo-landing .event-form label,.photo-landing .contact-form label{display:grid;gap:6px;font-weight:700;font-size:.9rem;color:var(--orange);padding:0;border:none;border-radius:0}.photo-landing .contact-form input,.photo-landing .contact-form textarea,.photo-landing .event-form input,.photo-landing .event-form textarea{border:1px solid rgba(245,130,31,.35);border-radius:8px;padding:10px}.photo-landing .event-form input[readonly],.photo-landing .event-form select[disabled]{cursor:not-allowed;background-color:#f0f0f0}.photo-landing input,.photo-landing select,.photo-landing textarea{width:100%;border:1px solid #e4c3a4;border-radius:6px;padding:10px;background:#fff;font:inherit}.photo-landing .section-orange{background:var(--orange)}.photo-landing .orange-grid{max-width:1120px;margin:0 auto;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.photo-landing .orange-card{background:#fff;border-radius:14px;padding:22px}.photo-landing .orange-card svg{color:var(--orange)}.photo-landing .orange-card h3{margin:12px 0 7px;font-size:1.3rem}.photo-landing .orange-card p{margin:0;color:var(--muted)}.photo-landing .flow-grid,.photo-landing .testimonial-grid,.photo-landing .faq-grid,.photo-landing .contact-grid,.photo-landing .footer-grid{max-width:1120px;margin:0 auto}.photo-landing .flow-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;max-width:1060px}.photo-landing .flow-card{background:#fff;border:1px solid #f3c89d;border-radius:12px;padding:24px 20px;min-height:220px}.photo-landing .flow-card svg{color:var(--orange);width:34px;height:34px}.photo-landing .flow-card h3{margin:12px 0 10px;font-size:1.2rem;line-height:1.2}.photo-landing .flow-card p{margin:0;color:var(--muted);font-size:.9rem;line-height:1.35}.photo-landing .testimonial-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;max-width:1100px}.photo-landing .testimonial{background:#fff;border:1px solid #f3c89d;border-radius:12px;padding:28px 24px 24px;text-align:center;min-height:280px}.photo-landing .testimonial img{width:72px;height:72px;border-radius:50%;object-fit:cover;margin-bottom:8px}.photo-landing .testimonial h3{margin:0 0 4px;font-size:2rem}.photo-landing .testimonial .role{color:#444;margin:0 0 8px;font-size:.95rem}.photo-landing .testimonial p{margin:0;color:var(--muted)}.photo-landing .testimonial-stars{margin:0 0 10px;font-size:1.6rem;line-height:1;letter-spacing:2px}.photo-landing .testimonial-stars .star.filled,.photo-landing .testimonial-stars .star.empty{color:var(--orange)}.photo-landing .testimonial-quote{color:#2f2f2f;font-size:1rem;line-height:1.35}.photo-landing .faq-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.photo-landing .faq-item{background:transparent;border:1px solid #f5c69a;border-radius:8px;color:#fff;padding:2px 12px}.photo-landing .faq-item summary{list-style:none;display:flex;justify-content:space-between;align-items:center;cursor:pointer;padding:10px 0}.photo-landing .faq-item summary::-webkit-details-marker{display:none}.photo-landing .faq-item p{margin:0 0 10px;color:#ffffffe6}.photo-landing .contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.photo-landing .contact-image{width:100%;height:460px;border-radius:10px;object-fit:cover}.photo-landing .contact-form{border:2px solid rgba(245,130,31,.4);border-radius:10px;background:#fff;padding:18px;text-align:left}.photo-landing .contact-form .cta-primary{margin:16px auto 0;display:block;border:1px solid #fff}.photo-landing .contact-feedback{margin-top:12px;text-align:center;font-weight:700;font-size:.95rem}.photo-landing .contact-feedback.success{color:#10b981}.photo-landing .contact-feedback.error{color:#ef4444}.photo-landing .contact-form h3{margin:0 0 4px;font-family:Sora,sans-serif;color:var(--orange)}.photo-landing .contact-form p{margin:0 0 14px;color:var(--muted)}.photo-landing .contact-form .cta-primary{margin:16px auto 0;width:150px;box-shadow:0 8px 14px #00000040,inset 0 -1px #fff3;text-shadow:0px 1px 5px rgba(0,0,0,.2)}.photo-landing .landing-footer{background:var(--light)!important;color:var(--ink);padding:36px 22px 0;margin-top:auto}.photo-landing .footer-grid{display:grid;grid-template-columns:1.2fr 1fr 1fr 1fr;gap:18px;background:var(--light)!important}.photo-landing #contact .section-title{color:var(--orange)!important}.photo-landing .footer-logo{width:140px;height:42px;background:#767676;color:#fff;display:grid;place-items:center;margin-bottom:14px}.photo-landing .landing-footer p{margin:0 0 12px;max-width:280px;color:#3f3f3f}.photo-landing .footer-socials{display:flex;gap:10px}.photo-landing .footer-socials svg{color:#111}.photo-landing .landing-footer h4{margin:0 0 8px;font-size:.9rem;color:var(--orange)}.photo-landing .landing-footer a{display:block;color:#222;text-decoration:none;margin-bottom:6px;font-size:.94rem}.photo-landing .copyright{background:var(--orange);color:#fff;border-top:none;margin-top:0;text-align:center;width:100%;padding:14px 12px;font-size:.9rem;position:static;bottom:auto;left:auto;z-index:auto}@media(max-width:1024px){.photo-landing .scale-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:980px){.photo-landing .mobile-nav-toggle{display:block}.photo-landing .landing-hero-nav{position:fixed;top:0;right:-100%;width:280px;height:100vh;background:#000000f2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);flex-direction:column;justify-content:center;align-items:center;padding:40px;transition:right .4s ease;z-index:999}.photo-landing .landing-hero-nav.active{right:0}.photo-landing .landing-hero-nav a{font-size:1.8rem;margin-bottom:20px}.photo-landing .scale-grid,.photo-landing .orange-grid,.photo-landing .flow-grid,.photo-landing .testimonial-grid,.photo-landing .contact-grid,.photo-landing .setup-grid,.photo-landing .footer-grid{grid-template-columns:repeat(2,1fr);gap:30px}}@media(max-width:980px){.photo-landing .landing-hero{min-height:100vh;background-position:center top}.photo-landing .landing-hero-header{padding:20px}.photo-landing .landing-hero-content{max-width:100%;align-self:stretch;padding:60px 40px 40px}.photo-landing .landing-hero-bottom-row{justify-content:center;flex-direction:column;text-align:center}}@media(max-width:640px){.photo-landing .landing-hero{min-height:85vh;background-position:center 20%;background-size:cover}.photo-landing .landing-hero-content{max-width:100%;align-self:stretch;padding:60px 20px 80px}.photo-landing .landing-hero-content h1{font-size:2.4rem}.photo-landing .landing-hero-content p{font-size:1.1rem;margin-bottom:40px;line-height:1.5}.photo-landing .landing-hero-bottom-row{gap:30px}.photo-landing .landing-hero-socials svg{width:40px;height:40px}.photo-landing .section{padding:60px 20px}.photo-landing .scale-grid,.photo-landing .orange-grid,.photo-landing .flow-grid,.photo-landing .testimonial-grid,.photo-landing .faq-grid,.photo-landing .contact-grid,.photo-landing .setup-grid,.photo-landing .footer-grid{grid-template-columns:1fr;gap:30px}.photo-landing .setup-image-box h3{font-size:2rem}.photo-landing .section-title{font-size:1.75rem;margin-bottom:24px}.photo-landing .scale-card h3{font-size:1.8rem}.photo-landing .scale-icon{width:48px;height:48px}.photo-landing .contact-image{height:300px}.photo-landing .event-form,.photo-landing .contact-form{padding:30px 20px}.photo-landing input,.photo-landing select,.photo-landing textarea{padding:14px;font-size:1rem}}@keyframes lp-slideInFromRight{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes lp-slideInFromLeft{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes lp-slideOutToLeft{0%{transform:translate(0)}to{transform:translate(-100%)}}@keyframes lp-slideOutToRight{0%{transform:translate(0)}to{transform:translate(100%)}}.photo-landing .slide-enter-from-right{animation:lp-slideInFromRight .35s ease-in-out forwards}.photo-landing .slide-enter-from-left{animation:lp-slideInFromLeft .35s ease-in-out forwards}.photo-landing .slide-exit-to-left{animation:lp-slideOutToLeft .35s ease-in-out forwards}.photo-landing .slide-exit-to-right{animation:lp-slideOutToRight .35s ease-in-out forwards}.photo-landing .slide-carousel{position:relative;overflow:hidden;min-height:420px}.photo-landing .slide-layer-exit{position:absolute;top:0;left:0;width:100%;pointer-events:none}.landing-page{--background: 215 25% 20%;--foreground: 199 89% 98%;--primary: 199 89% 52%;--primary-foreground: 210 40% 98%;--secondary: 215 25% 25%;--muted-foreground: 215 20% 80%;--border: 215 28% 40%;--shadow-xs: 0 0 0 0 transparent;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .2);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .2);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .3)}.landing-page{font-family:var(--font-sans);background:hsl(var(--background));color:hsl(var(--foreground));min-height:100vh;line-height:1.5;-webkit-font-smoothing:antialiased;position:relative}.landing-page *{box-sizing:border-box;margin:0;padding:0}.landing-page .container{max-width:1400px;margin:0 auto;padding:0 2rem}.landing-page .italic-text{font-family:var(--font-serif);font-style:italic}.landing-page .neural-background{position:fixed;inset:0;pointer-events:none;overflow:hidden;z-index:0}.landing-page .scan-line-container,.landing-page .scan-line,.landing-page .scan-line-overlay{display:none}.landing-page .grid-pattern{position:absolute;inset:0;width:100%;height:100%;opacity:.015;background-image:linear-gradient(#333 1px,transparent 1px),linear-gradient(90deg,#333 1px,transparent 1px);background-size:60px 60px;-webkit-mask-image:radial-gradient(circle at center,black,transparent 70%);mask-image:radial-gradient(circle at center,black,transparent 70%)}.landing-page .glow-orb,.landing-page .glow-orb-1,.landing-page .glow-orb-2{display:none}.landing-page .landing-header{position:sticky;top:0;z-index:200;background:#18202acc!important;color:hsl(var(--foreground))!important;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,255,255,.05);transition:all .3s}.landing-page .landing-header.scrolled{background:#fffffff2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--shadow-sm)}.landing-page .header-container{display:flex;align-items:center;justify-content:space-between;padding:1rem 2rem;max-width:1400px;margin:0 auto}.landing-page .header-brand{font-family:var(--font-sans);font-size:1.25rem;font-weight:700;display:flex;align-items:center;gap:.5rem;cursor:pointer}.landing-page .brand-dot{width:8px;height:8px;background:hsl(var(--foreground));animation:pulse 2s infinite}.landing-page .header-nav{display:flex;align-items:center;gap:2rem}.landing-page .header-nav a{font-size:.875rem;font-weight:500;text-decoration:none;color:inherit;transition:opacity .2s}.landing-page .header-nav a:hover{opacity:.7}.landing-page .btn-primary{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 2rem;font-size:.95rem;font-weight:600;background:linear-gradient(135deg,#0da2e7,#00c1d6);color:#fff;border:none;border-radius:9999px;box-shadow:0 0 20px #06b6d44d;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1)}.landing-page .btn-primary:hover{transform:translateY(-2px);box-shadow:0 0 30px #06b6d480;background:linear-gradient(135deg,#26b2f2,#00e5ff)}.landing-page .btn-primary-sm{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1.25rem;font-size:.875rem;font-weight:600;background:#ffffff1a;color:hsl(var(--foreground));border-radius:9999px;border:1px solid rgba(255,255,255,.2);cursor:pointer;transition:all .2s ease}.landing-page .btn-secondary{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 2rem;font-size:.95rem;font-weight:600;background:transparent;color:hsl(var(--foreground));border:1px solid rgba(255,255,255,.1);border-radius:9999px;cursor:pointer;transition:all .2s ease}.landing-page .btn-secondary:hover{background:#ffffff0d;border-color:#38bdf8;color:#38bdf8}.landing-page .hero-section{min-height:calc(100dvh - 70px);display:flex;flex-direction:column;justify-content:center;padding:5rem 0;position:relative;overflow:hidden}.landing-page .hero-grid{display:grid;grid-template-columns:1fr;gap:3rem;align-items:center}@media(min-width:1024px){.landing-page .hero-grid{grid-template-columns:1fr 1fr;gap:4rem}}.landing-page .hero-content{display:flex;flex-direction:column;gap:2rem}.landing-page .hero-badge{display:inline-block;width:fit-content;border:2px solid hsl(var(--border));padding:.5rem 1rem;font-family:var(--font-mono);font-size:.875rem;box-shadow:var(--shadow-xs)}.landing-page .hero-title{font-size:clamp(2.5rem,5vw,4.5rem);font-weight:700;line-height:1.1;letter-spacing:-.025em;background:linear-gradient(135deg,hsl(var(--foreground)),hsl(var(--muted-foreground)));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:hsl(var(--foreground))}.landing-page .hero-title span{display:inline-block}.landing-page .hero-title-italic{font-family:var(--font-serif);font-style:italic}.landing-page .hero-description{font-size:1.125rem;color:hsl(var(--muted-foreground));max-width:28rem;line-height:1.625}.landing-page .hero-buttons{display:flex;flex-wrap:wrap;gap:1rem}.landing-page .hero-stats{display:flex;align-items:center;gap:2rem;padding-top:1rem;font-family:var(--font-mono);font-size:.875rem;color:hsl(var(--muted-foreground))}.landing-page .stat-item{display:flex;flex-direction:column}.landing-page .stat-value{font-size:1.5rem;font-weight:700;color:hsl(var(--foreground))}.landing-page .stat-label{font-size:.875rem;color:hsl(var(--muted-foreground))}.landing-page .stat-divider{width:1px;height:3rem;background:hsl(var(--border))}.landing-page .hero-image-container{position:relative}.landing-page .hero-image-box{border:2px solid hsl(var(--border));box-shadow:var(--shadow-lg);overflow:hidden}.landing-page .scan-line-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 50%,rgba(0,0,0,.5) 51%);background-size:100% 4px;opacity:0;transition:opacity .3s;pointer-events:none}.landing-page .hero-image-box:hover .scan-line-overlay{opacity:.3}.landing-page .hero-image-content{width:100%;aspect-ratio:4 / 3;background:linear-gradient(135deg,hsl(var(--secondary)),#e6e6e6);display:flex;flex-direction:column;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:.875rem;transition:transform .7s}.landing-page .hero-image-box:hover .hero-image-content{transform:scale(1.05)}.landing-page .hero-emoji{font-size:4rem;margin-bottom:1rem}@keyframes cinematicFloat{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-10px) scale(1.02)}}@keyframes cinematicEntrance{0%{opacity:0;transform:scale(.9) translateY(20px);filter:blur(10px)}to{opacity:1;transform:scale(1) translateY(0);filter:blur(0)}}@keyframes glowPulse{0%,to{box-shadow:0 0 20px #00ff881a;border-color:#333}50%{box-shadow:0 0 35px #0f83;border-color:#00ff884d}}.landing-page .hero-image-animate{animation:cinematicFloat 6s ease-in-out infinite;will-change:transform}.landing-page .hero-element-entrance{animation:cinematicEntrance 1.2s cubic-bezier(.2,.8,.2,1) forwards}.landing-page .hero-image-box.dark-mode{background:#000;border:1px solid #333;animation:glowPulse 4s infinite}.landing-page .hero-image-text{color:hsl(var(--muted-foreground))}.landing-page .floating-card{position:absolute;bottom:-1rem;right:-1rem;width:8rem;height:8rem;border:2px solid hsl(var(--border));background:hsl(var(--background));box-shadow:var(--shadow-sm);display:flex;flex-direction:column;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:.75rem;animation:float 3s ease-in-out infinite;cursor:pointer;z-index:10;opacity:0;animation:cinematicEntrance 1s .5s forwards,float 3s 1.5s ease-in-out infinite}.landing-page .floating-card-icon{font-size:1.5rem;font-weight:700}.landing-page .node{position:absolute;border:2px solid hsl(var(--border));animation:neuralPulse 2s ease-out infinite}.landing-page .node-1{top:-1rem;left:-1rem;width:1rem;height:1rem;background:hsl(var(--foreground))}.landing-page .node-2{top:50%;left:-1rem;width:.75rem;height:.75rem;background:hsl(var(--background));animation-delay:.5s}.landing-page .node-3{top:-1rem;left:50%;width:.75rem;height:.75rem;background:hsl(var(--background));animation-delay:1s}.landing-page .features-section{padding:6rem 0;background:hsl(var(--secondary));position:relative;overflow:hidden}.landing-page .section-grid-bg{position:absolute;inset:0;opacity:.02;background-image:linear-gradient(hsl(var(--foreground)) 1px,transparent 1px),linear-gradient(90deg,hsl(var(--foreground)) 1px,transparent 1px);background-size:50px 50px}.landing-page .section-header{max-width:42rem;margin-bottom:4rem}.landing-page .section-title{font-size:clamp(2rem,4vw,3rem);font-weight:700;margin-bottom:1.5rem}.landing-page .section-subtitle{font-size:1.125rem;color:hsl(var(--muted-foreground))}.landing-page .features-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}@media(min-width:768px){.landing-page .features-grid{grid-template-columns:repeat(2,1fr)}}.landing-page .feature-card{background:hsl(var(--background));border:2px solid hsl(var(--border));padding:2rem;box-shadow:var(--shadow-sm);transition:all .5s ease;cursor:pointer;position:relative;overflow:hidden}.landing-page .feature-card:before{content:none}.landing-page .feature-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1rem)}.landing-page .feature-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.5rem}.landing-page .feature-number{font-family:var(--font-mono);font-size:.875rem;color:hsl(var(--muted-foreground))}.landing-page .feature-arrow{width:2rem;height:2rem;border:2px solid hsl(var(--border));display:flex;align-items:center;justify-content:center;transition:all .3s}.landing-page .feature-card:hover .feature-arrow{background:hsl(var(--foreground));color:hsl(var(--background));transform:rotate(45deg)}.landing-page .feature-title{font-size:1.5rem;font-weight:700;margin-bottom:1rem}.landing-page .feature-description{color:hsl(var(--muted-foreground));line-height:1.625}.landing-page .frameworks-section{padding:6rem 0;position:relative}.landing-page .section-header-row{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:3rem}@media(min-width:768px){.landing-page .section-header-row{flex-direction:row;align-items:flex-start;justify-content:space-between}.landing-page .section-header-row .section-header{margin-bottom:0;max-width:70%}}.landing-page .section-badge{font-family:var(--font-mono);font-size:.75rem;color:hsl(var(--muted-foreground));background:rgba(var(--primary),.1);padding:.5rem 1rem;border-radius:999px;border:1px solid rgba(var(--primary),.2);display:flex;align-items:center;gap:.5rem;white-space:nowrap;height:fit-content;margin-top:.5rem;margin-bottom:0}.landing-page .section-badge{font-family:var(--font-mono);font-size:.8rem;color:hsl(var(--muted-foreground));background:rgba(var(--primary),.1);padding:.95rem .9rem;border-radius:999px;border:1px solid rgba(var(--primary),.2);display:flex;align-items:center;gap:.5rem;white-space:nowrap}.landing-page .badge-dot{width:.4rem;height:.4rem;background:hsl(var(--primary));border-radius:50%;animation:pulse 2s infinite}.landing-page .frameworks-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}@media(min-width:768px){.landing-page .frameworks-grid{grid-template-columns:repeat(4,1fr)}}.landing-page .framework-card{background:hsl(var(--background));border:2px solid hsl(var(--border));padding:1.5rem;transition:all .3s ease;cursor:pointer;position:relative}.landing-page .feature-card:after,.landing-page .framework-card:after{content:"";position:absolute;top:0;left:-100%;width:50%;height:100%;background:linear-gradient(to right,transparent 0%,rgba(6,182,212,.1) 50%,transparent 100%);transform:skew(-25deg);transition:none;pointer-events:none}.landing-page .feature-card:hover:after,.landing-page .framework-card:hover:after{left:200%;transition:left .75s ease-in-out}.landing-page .feature-card:hover,.landing-page .framework-card:hover{background:hsl(var(--background));box-shadow:var(--shadow-md),0 0 0 1px #06b6d480;transform:translateY(-.5rem)}.landing-page .framework-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:2rem}.landing-page .framework-number{font-family:var(--font-mono);font-size:.75rem;color:hsl(var(--muted-foreground))}.landing-page .framework-tag{font-family:var(--font-mono);font-size:.75rem;border:1px solid hsl(var(--border));padding:.25rem .5rem;transition:all .3s}.landing-page .framework-card:hover .framework-tag{background:hsl(var(--foreground));color:hsl(var(--background))}.landing-page .framework-name{font-size:1.25rem;font-weight:700}.landing-page .framework-card:hover .framework-name{text-decoration:underline;text-underline-offset:4px}.landing-page .form-group{margin-bottom:1.5rem}.landing-page .form-label{display:block;font-family:var(--font-mono);font-size:.875rem;font-weight:500;margin-bottom:.5rem;color:hsl(var(--foreground))}.landing-page .form-input,.landing-page .form-select{width:100%;padding:1.25rem 1.5rem;font-family:var(--font-mono);font-size:1rem;background:#0f172a99;border:1px solid var(--color-border);border-radius:12px;color:var(--color-text);transition:all .2s;box-shadow:none}.landing-page .form-input:focus,.landing-page .form-select:focus{outline:none;border-color:var(--color-primary);background:#0f172acc;box-shadow:0 0 0 2px #38bdf833}.landing-page .form-input:focus,.landing-page .form-select:focus{outline:none;transform:translate(-1px,-1px);box-shadow:4px 4px #000}.landing-page .form-input::placeholder{color:#888}.landing-page .form-checkbox-group{display:flex;align-items:flex-start;gap:1rem;background:#fff;padding:1.25rem;border:2px solid black;box-shadow:4px 4px #000}.landing-page .form-checkbox{width:1.25rem;height:1.25rem;border:2px solid hsl(var(--border));border-radius:0;cursor:pointer;accent-color:hsl(var(--foreground))}.photo-cluster-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;width:100%;margin-top:2rem}@media(min-width:640px){.photo-cluster-grid{grid-template-columns:repeat(3,1fr);gap:1.25rem}}@media(min-width:768px){.photo-cluster-grid{grid-template-columns:repeat(4,1fr);gap:1.5rem}}@media(min-width:1024px){.photo-cluster-grid{grid-template-columns:repeat(5,1fr)}}@media(min-width:1280px){.photo-cluster-grid{grid-template-columns:repeat(6,1fr)}}.landing-page .registration-card{background:hsl(var(--background));border:2px solid hsl(var(--border));box-shadow:var(--shadow-md);padding:2.5rem;position:relative;overflow:hidden}.landing-page .upload-zone{border:2px dashed hsl(var(--border));padding:2rem;text-align:center;cursor:pointer;transition:all .3s;background:hsl(var(--secondary) / .5)}.landing-page .upload-zone:hover{background:hsl(var(--secondary));border-color:hsl(var(--foreground))}.landing-page .camera-container{position:relative;border:2px solid hsl(var(--border));background:#000;overflow:hidden}.landing-page .camera-overlay{position:absolute;inset:0;pointer-events:none;border:1px solid rgba(0,255,136,.3);box-shadow:inset 0 0 50px #00ff881a}.landing-page .camera-corner{position:absolute;width:2rem;height:2rem;border:2px solid rgba(0,255,136,.8);transition:all .3s}.landing-page .camera-container:hover .camera-corner{width:3rem;height:3rem;border-color:#0f8;box-shadow:0 0 15px #0f86}.landing-page .footer-grid{display:grid;grid-template-columns:1fr;gap:3rem}@media(min-width:768px){.landing-page .footer-grid{grid-template-columns:2fr 1fr 1fr}}.landing-page .footer-brand-section{max-width:24rem}.landing-page .footer-brand{font-family:var(--font-mono);font-size:1.25rem;font-weight:700;margin-bottom:1rem}.landing-page .footer-description{color:hsl(var(--muted-foreground));margin-bottom:1.5rem;line-height:1.625}.landing-page .footer-socials{display:flex;gap:1rem;font-family:var(--font-mono);font-size:.875rem}.landing-page .footer-socials a{text-decoration:none;color:inherit}.landing-page .footer-socials a:hover{text-decoration:underline}.landing-page .footer-links h4{font-weight:700;margin-bottom:1rem}.landing-page .footer-links ul{list-style:none;display:flex;flex-direction:column;gap:.5rem}.landing-page .footer-links a{color:hsl(var(--muted-foreground));text-decoration:none;transition:color .2s}.landing-page .footer-links a:hover{color:hsl(var(--foreground))}.landing-page .footer-bottom{margin-top:4rem;padding-top:2rem;border-top:1px solid hsl(var(--border));display:flex;flex-direction:column;gap:1rem;font-size:.875rem;color:hsl(var(--muted-foreground))}@media(min-width:768px){.landing-page .footer-bottom{flex-direction:row;justify-content:space-between;align-items:center}}.landing-page .footer-tagline{font-family:var(--font-mono)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px);filter:blur(4px)}to{opacity:1;transform:translateY(0);filter:blur(0)}}.animate-fade-in{animation:fadeInUp 1.2s cubic-bezier(.25,.46,.45,.94) forwards;opacity:0}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes neuralPulse{0%{box-shadow:0 0 #0006}70%{box-shadow:0 0 0 15px #0000}to{box-shadow:0 0 #0000}}@keyframes pulseGlow{0%,to{opacity:.4;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes scanLine{0%{top:0%}to{top:100%}}.landing-page .hero-title,.landing-page .section-title,.landing-page .feature-title,.landing-page .framework-name,.landing-page .footer-brand,.landing-page .footer-links h4{color:#fff!important}.landing-page .hero-description,.landing-page .section-subtitle,.landing-page .feature-description,.landing-page .feature-number,.landing-page .stat-label,.landing-page .text-muted-foreground{color:#ffeded!important}@keyframes glitch{0%{transform:translate(0)}20%{transform:translate(-2px,2px)}40%{transform:translate(-2px,-2px)}60%{transform:translate(2px,2px)}80%{transform:translate(2px,-2px)}to{transform:translate(0)}}.landing-page .hero-title:hover{animation:glitch .3s cubic-bezier(.25,.46,.45,.94) both infinite;color:#000}.landing-page .animate-fade-in{opacity:0;animation:fadeInUp .8s cubic-bezier(.16,1,.3,1) forwards;animation-fill-mode:both}.landing-page{background:#fff!important;color:#000!important}.landing-page .feature-card,.landing-page .framework-card,.landing-page .floating-card{background:#fff!important;border:2px solid #000000!important}.landing-page .features-section,.landing-page .framework-card:hover{background:#f5f5f5!important}.landing-page .global-particles{position:fixed!important;top:0;left:0;width:100vw;height:100vh;z-index:0!important;pointer-events:none}.landing-page>*:not(.global-particles){position:relative;z-index:2}.landing-page .neural-background{z-index:1}.cyber-image-container{width:100%;height:120px;position:relative;overflow:hidden;margin-bottom:1rem;border-bottom:1px solid rgba(56,189,248,.2)}.cyber-image-container img{width:100%;height:100%;object-fit:cover;filter:saturate(.8) brightness(.8);transition:transform .6s cubic-bezier(.16,1,.3,1)}.cyber-card:hover .cyber-image-container img{transform:scale(1.1);filter:saturate(1.2) brightness(1)}.cyber-image-mask{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 60%,rgba(15,23,42,.95) 100%);z-index:2}.cyber-image-overlay{position:absolute;inset:0;background:repeating-linear-gradient(0deg,rgba(0,0,0,0) 0px,rgba(0,0,0,.1) 1px,transparent 2px);pointer-events:none;z-index:3}.neural-aura{position:absolute;inset:-1px;border-radius:inherit;z-index:-1;background:transparent;box-shadow:0 0 15px #38bdf800;transition:all .5s ease;pointer-events:none}.cyber-card:hover .neural-aura{animation:neural-glow 3s infinite alternate cubic-bezier(.4,0,.2,1)}@keyframes neural-glow{0%{box-shadow:0 0 10px #38bdf81a,inset 0 0 5px #38bdf80d}to{box-shadow:0 0 25px #38bdf866,inset 0 0 10px #38bdf81a}}.cyber-card:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at center,rgba(56,189,248,.03) 0%,transparent 70%);opacity:0;transition:opacity .5s ease;pointer-events:none}.cyber-card:hover:before{opacity:1}.demo-page-light{--background: 0 0% 100%;--foreground: 222 47% 11%;--muted: 210 40% 96.1%;--muted-foreground: 215 16% 47%;--popover: 0 0% 100%;--popover-foreground: 222 47% 11%;--card: 0 0% 100%;--card-foreground: 222 47% 11%;--border: 214 32% 91%;--input: 214 32% 91%;--primary: 221 83% 53%;--primary-foreground: 210 40% 98%;--secondary: 210 40% 96.1%;--secondary-foreground: 222 47% 11%;--accent: 210 40% 96.1%;--accent-foreground: 222 47% 11%;--destructive: 0 84.2% 60.2%;--destructive-foreground: 210 40% 98%;--ring: 221 83% 53%;--radius: .75rem;font-family:var(--font-sans);background-color:hsl(var(--background));color:hsl(var(--foreground));min-height:100dvh;position:relative;overflow-x:hidden}.demo-page-light .demo-container{max-width:1600px;margin:0 auto;min-height:100dvh;padding:1.5rem;display:flex;align-items:center;position:relative;z-index:10}.demo-split-layout{display:grid;grid-template-columns:1fr;gap:4rem;width:100%;align-items:center}@media(min-width:1024px){.demo-split-layout{grid-template-columns:1fr 1fr;gap:6rem}}.demo-content-side{max-width:650px}.demo-title-large{font-size:clamp(2.5rem,8vw,5rem);line-height:1.05;margin-bottom:2rem;background:linear-gradient(135deg,#0f1729,#65758b);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-.03em;font-weight:800}.demo-feature-list{margin:3rem 0;display:flex;flex-direction:column;gap:1.5rem}.demo-feature-item{display:flex;align-items:center;gap:1rem;font-size:1.1rem;color:hsl(var(--muted-foreground));font-weight:500}.demo-feature-icon{width:2rem;height:2rem;border-radius:50%;background:#ecf2fd;color:#2463eb;display:flex;align-items:center;justify-content:center}.demo-status-panel{background:#fff;border:1px solid hsl(var(--border));border-radius:1rem;padding:1.5rem;display:flex;gap:2rem;margin-top:2rem;box-shadow:var(--shadow-sm);width:fit-content}.status-item{display:flex;flex-direction:column}.status-label{font-size:.75rem;text-transform:uppercase;color:hsl(var(--muted-foreground));font-weight:600;letter-spacing:.05em;margin-bottom:.25rem}.status-value{font-family:var(--font-mono);font-weight:700;color:hsl(var(--foreground));display:flex;align-items:center;gap:.5rem}.status-dot{width:8px;height:8px;background:#16a249;border-radius:50%;box-shadow:0 0 0 2px #d2f9e0;animation:pulse 2s infinite}.demo-cards-side{display:flex;flex-direction:column;gap:1.5rem}.demo-card-row{display:grid;gap:1.5rem}@media(min-width:768px){.demo-cards-side{display:grid;grid-template-columns:repeat(2,1fr);grid-template-rows:auto auto}.card-organizer{grid-column:1 / -1}}.demo-page-light .demo-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.35rem .85rem;background:#fff;border:1px solid hsl(var(--border));border-radius:9999px;font-size:.75rem;font-weight:600;letter-spacing:.02em;color:hsl(var(--muted-foreground));box-shadow:var(--shadow-sm);margin-bottom:2rem}.demo-page-light .demo-badge-dot{width:6px;height:6px;border-radius:50%;background:#16a249;box-shadow:0 0 0 2px #d2f9e0}.demo-page-light .demo-title{font-family:var(--font-sans);font-size:clamp(2.5rem,5vw,4rem);font-weight:700;letter-spacing:-.025em;line-height:1.1;color:hsl(var(--foreground));margin-bottom:1.5rem}.demo-page-light .demo-title span{background:linear-gradient(135deg,#2463eb,#7c3bed);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.demo-page-light .demo-description{font-size:1.125rem;color:hsl(var(--muted-foreground));line-height:1.7;max-width:640px;margin:0 auto 4rem}.demo-page-light .demo-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:2rem;width:100%}.demo-page-light .demo-card{background:#fff;border:1px solid hsl(var(--border));border-radius:1rem;padding:2.5rem;transition:all .4s cubic-bezier(.2,.8,.2,1);display:flex;flex-direction:column;position:relative;overflow:hidden;cursor:pointer}.demo-page-light .demo-card:hover{transform:translateY(-8px);box-shadow:0 20px 25px -5px #0000000d,0 8px 10px -6px #00000003;border-color:#2463eb}.demo-page-light .card-icon-wrapper{width:3.5rem;height:3.5rem;border-radius:1rem;display:flex;align-items:center;justify-content:center;margin-bottom:2rem;transition:all .3s ease}.demo-page-light .card-organizer .card-icon-wrapper{background:#ecf2fd;color:#2463eb}.demo-page-light .card-organizer:hover .card-icon-wrapper{background:#2463eb;color:#fff}.demo-page-light .card-photographer .card-icon-wrapper{background:#f6f1fe;color:#7c3bed}.demo-page-light .card-photographer:hover .card-icon-wrapper{background:#7c3bed;color:#fff}.demo-page-light .card-attendee .card-icon-wrapper{background:#eefcf3;color:#21c45d}.demo-page-light .card-attendee:hover .card-icon-wrapper{background:#21c45d;color:#fff}.demo-page-light .card-title{font-size:1.5rem;font-weight:700;color:hsl(var(--foreground));margin-bottom:.75rem;letter-spacing:-.01em}.demo-page-light .card-text{color:hsl(var(--muted-foreground));font-size:.95rem;line-height:1.6;flex-grow:1;margin-bottom:2rem}.demo-page-light .card-action{font-weight:600;font-size:.9rem;display:flex;align-items:center;gap:.5rem;transition:gap .2s ease}.demo-page-light .card-organizer .card-action{color:#2463eb}.demo-page-light .card-photographer .card-action{color:#7c3bed}.demo-page-light .card-attendee .card-action{color:#21c45d}.demo-page-light .demo-card:hover .card-action{gap:.75rem}.demo-page-light .ambient-bg{position:absolute;inset:0;overflow:hidden;z-index:0;pointer-events:none}.demo-page-light .ambient-blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:.6}.demo-page-light .blob-1{width:60vw;height:60vw;background:radial-gradient(circle,hsl(210,100%,96%) 0%,transparent 70%);top:-20%;left:-10%}.demo-page-light .blob-2{width:50vw;height:50vw;background:radial-gradient(circle,hsl(250,100%,97%) 0%,transparent 70%);bottom:-10%;right:-10%}@keyframes slideIn{0%{transform:translateY(100%) scale(.9);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}@keyframes fadeOut{to{opacity:0;transform:translateY(10px)}}.ai-toast-container{position:fixed;top:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:12px;pointer-events:none;align-items:flex-end}.ai-toast{pointer-events:auto;width:360px;max-width:90vw;background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:16px;display:flex;align-items:flex-start;gap:12px;box-shadow:0 4px 6px -1px #0000000d,0 10px 15px -3px #0000000d;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;position:relative;overflow:hidden;transform-origin:bottom center}@media(prefers-color-scheme:dark){.ai-toast{background:#1e293b;border-color:#334155;color:#f8fafc}}.ai-toast-icon{flex-shrink:0;margin-top:2px;display:flex;align-items:center;justify-content:center}.ai-toast-content{flex:1;display:flex;flex-direction:column;gap:4px}.ai-toast-title{font-size:.95rem;font-weight:600;color:#0f172a;display:flex;align-items:center;gap:8px;text-transform:capitalize}@media(prefers-color-scheme:dark){.ai-toast-title{color:#f1f5f9}}.ai-toast-message{font-size:.875rem;line-height:1.5;color:#64748b}@media(prefers-color-scheme:dark){.ai-toast-message{color:#94a3b8}}.ai-toast-close{background:transparent;border:none;color:#94a3b8;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s ease;display:flex;align-items:center;justify-content:center;margin-left:8px;margin-top:-4px}.ai-toast-close:hover{background:#f1f5f9;color:#475569}@media(prefers-color-scheme:dark){.ai-toast-close:hover{background:#334155;color:#cbd5e1}}.ai-toast.success .ai-toast-icon{color:#10b981}.ai-toast.error .ai-toast-icon{color:#ef4444}.ai-toast.info .ai-toast-icon{color:#3b82f6}.ai-toast.processing .ai-toast-icon{color:#f59e0b}.ai-toast.processing .ai-toast-icon svg{animation:spin 2s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.ai-loader-overlay,.ai-loader-inline{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#ffffffe6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:10000;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#0f172a;font-family:Inter,sans-serif}@media(prefers-color-scheme:dark){.ai-loader-overlay,.ai-loader-inline{background:#0f172ae6;color:#f8fafc}}.ai-loader-inline{position:absolute;width:100%;height:100%}.ai-loader-rings{position:relative;width:64px;height:64px;margin-bottom:2rem}.spinner-ring{position:absolute;inset:0;border-radius:50%;border:3px solid transparent;border-top-color:#ea580c;animation:spin 1s cubic-bezier(.55,.055,.675,.19) infinite}.spinner-ring:before{content:"";position:absolute;inset:-6px;border-radius:50%;border:3px solid transparent;border-top-color:#ea580c66;animation:spin 2s cubic-bezier(.55,.055,.675,.19) infinite reverse}.loader-text-container{text-align:center;display:flex;flex-direction:column;gap:8px;animation:fadeIn .5s ease-out}.loader-title{font-size:1.125rem;font-weight:600;letter-spacing:-.01em;color:#1e293b}@media(prefers-color-scheme:dark){.loader-title{color:#f1f5f9}}.loader-subtitle{font-size:.875rem;color:#64748b}@media(prefers-color-scheme:dark){.loader-subtitle{color:#94a3b8}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.cluster-viewer{padding:20px;max-width:1200px;margin:0 auto}.viewer-header{display:flex;align-items:center;margin-bottom:24px;gap:16px}.back-btn{background-color:#f0f0f0;border:none;border-radius:4px;padding:8px 16px;cursor:pointer;font-size:14px;font-weight:500;display:flex;align-items:center;transition:background-color .2s}.back-btn:hover{background-color:#e0e0e0}.cluster-info{display:flex;align-items:center;gap:12px}.cluster-info h1{margin:0;font-size:24px;color:#333}.edit-name-btn{background-color:#f0f0f0;border:none;border-radius:4px;padding:8px 12px;cursor:pointer;font-size:14px;font-weight:500;transition:background-color .2s}.edit-name-btn:hover{background-color:#e0e0e0}.faces-stats{margin-bottom:16px;color:#666}.cluster-viewer .photos-grid{display:flex!important;flex-wrap:wrap;gap:20px;margin-bottom:24px}.cluster-viewer .photo-container{position:relative;background-color:#f5f5f5;border-radius:8px;overflow:hidden;cursor:pointer;transition:transform .2s,box-shadow .2s;flex:0 0 300px;max-width:300px}.cluster-viewer .photo-container:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.photo-wrapper{position:relative;width:100%;height:250px;overflow:hidden;background-color:#000}.cluster-photo{width:100%;height:100%;object-fit:contain;display:block}.bounding-box-overlay,.bounding-box-container{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.bounding-box-svg{position:absolute;top:0;left:0;width:100%;height:100%}.face-bounding-box{position:absolute;border:3px solid #2196f3;border-radius:4px;box-shadow:0 0 0 1px #ffffff80;transition:all .2s ease;pointer-events:none}.photo-container:hover .face-bounding-box{border-color:#ff9800;box-shadow:0 0 0 2px #fffc,0 0 20px #2196f380}.face-label{position:absolute;top:-28px;left:0;background-color:#2196f3;color:#fff;padding:4px 8px;font-size:14px;font-weight:700;border-radius:4px 4px 0 0;white-space:nowrap;box-shadow:0 -2px 4px #0003;transition:background-color .2s}.photo-container:hover .face-label{background-color:#ff9800}.face-box{stroke-width:3;transition:stroke .2s ease}.photo-container:hover .face-box{stroke:#ff9800;stroke-width:4}.label-background{opacity:.9;transition:fill .2s ease}.photo-container:hover .label-background{fill:#ff9800}.face-label-text{font-family:Arial,sans-serif;text-shadow:0 1px 2px rgba(0,0,0,.5)}.photo-info{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.7),transparent);padding:12px;display:flex;justify-content:space-between;align-items:flex-end}.confidence-badge{background-color:#2196f3e6;color:#fff;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500}.faces-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:12px;margin-bottom:24px}.pagination{display:flex;justify-content:center;align-items:center;margin-top:24px;gap:16px}.page-btn{background-color:#2196f3;color:#fff;border:none;border-radius:4px;padding:8px 16px;cursor:pointer;font-size:14px;font-weight:500;transition:background-color .2s}.page-btn:hover{background-color:#1976d2}.page-btn.disabled{background-color:#ccc;cursor:not-allowed}.page-info{font-size:14px;color:#666}.name-edit-form{display:flex;flex-direction:column;margin-left:16px}.name-input{font-size:16px;padding:8px;border:1px solid #ddd;border-radius:4px;margin-bottom:8px;min-width:250px}.edit-actions{display:flex;gap:8px}.save-btn,.cancel-btn{padding:6px 12px;border-radius:4px;border:none;font-size:14px;cursor:pointer;transition:background-color .2s}.save-btn{background-color:#4caf50;color:#fff}.save-btn:hover{background-color:#388e3c}.cancel-btn{background-color:#f44336;color:#fff}.cancel-btn:hover{background-color:#d32f2f}.save-btn:disabled,.cancel-btn:disabled{background-color:#ccc;cursor:not-allowed}.face-detail-modal{position:fixed;inset:0;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background-color:#fff;border-radius:8px;padding:16px;max-width:90%;max-height:90%;overflow:auto;position:relative}.close-btn{position:absolute;top:8px;right:8px;background:none;border:none;font-size:24px;cursor:pointer;color:#666}.close-btn:hover{color:#333}.face-detail{display:flex;flex-direction:column}.face-image-container{position:relative;margin-bottom:16px;overflow:hidden}.full-photo{max-width:100%;max-height:70vh;object-fit:contain}.face-highlight{position:absolute;border:3px solid #ff9800;box-shadow:0 0 0 2px #ffffff80}.face-metadata{background-color:#f5f5f5;border-radius:4px;padding:12px}.face-metadata p{margin:8px 0}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;text-align:center}.loading-spinner{border:4px solid rgba(0,0,0,.1);border-radius:50%;border-top:4px solid #2196f3;width:40px;height:40px;animation:spin 1s linear infinite;margin-bottom:16px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-container{text-align:center;padding:40px;background-color:#fff3f3;border-radius:8px;margin:20px 0}.error-message{color:#f44336;font-size:16px;margin-bottom:16px}.retry-btn{background-color:#f44336;color:#fff;border:none;border-radius:4px;padding:8px 16px;cursor:pointer;font-size:14px;font-weight:500;margin-right:8px}.retry-btn:hover{background-color:#d32f2f}.empty-container{text-align:center;padding:40px;background-color:#f5f5f5;border-radius:8px}.empty-container h2{margin-top:0;color:#333}.empty-container p{color:#666}@media(max-width:768px){.viewer-header{flex-direction:column;align-items:flex-start}.cluster-info{margin-top:16px}.cluster-viewer .photos-grid{gap:12px}.cluster-viewer .photo-container{flex:0 0 200px;max-width:200px}.cluster-viewer .cluster-photo{height:180px}.faces-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr))}.face-detail{flex-direction:column}}@media(max-width:480px){.cluster-viewer .photo-container{flex:0 0 150px;max-width:150px}.cluster-viewer .cluster-photo{height:150px}}.photo-clustering-page{min-height:100vh;background-color:#fff;color:#1e293b;font-family:Inter,-apple-system,sans-serif;position:relative;overflow-x:hidden}.page-header{padding:1.5rem 2.5rem;border-bottom:1.5px solid #FED7AA;background-color:#ffffffe6;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;width:100%}.header-engine-text{font-size:.8rem;color:#f97316;font-weight:800;text-transform:uppercase;letter-spacing:.1em}.content-container{padding:5rem 2rem;max-width:900px;margin:0 auto;width:100%;position:relative;z-index:1}.hero-section{text-align:center;margin-bottom:4rem}.hero-title{font-size:2.5rem;font-weight:900;color:#000!important;-webkit-text-fill-color:initial!important;background:none!important;margin-bottom:1.25rem;letter-spacing:-.04em;font-family:Outfit,sans-serif}.hero-description{font-size:1.15rem;color:#000!important;max-width:550px;margin:0 auto;line-height:1.6;font-weight:500}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:3rem}.action-area{background:#fff7ed;border-radius:20px;padding:3rem 2rem;border:2px dashed #FED7AA;text-align:center;position:relative;overflow:hidden}.primary-action-button{padding:1.25rem 3.5rem;border-radius:100px;font-size:1.15rem;font-weight:800;display:flex;align-items:center;gap:1rem;transition:all .3s cubic-bezier(.4,0,.2,1);width:fit-content;margin:0 auto}.secondary-action-button{padding:1.5rem 4rem;border-radius:100px;font-size:1.25rem;font-weight:900;display:inline-flex;align-items:center;gap:1rem;transition:all .3s cubic-bezier(.4,0,.2,1);font-family:Outfit,sans-serif}.modal-window{position:relative;width:100%;max-width:480px;background:#fff;border-radius:32px;padding:3rem 2.5rem!important;text-align:center;box-shadow:0 25px 50px -12px #f9731633;border:1.5px solid #FED7AA}@media(max-width:1024px){.hero-title{font-size:2.2rem}}@media(max-width:768px){.page-header{padding:1rem 1.5rem}.content-container{padding:3rem 1.5rem}.hero-title{font-size:2rem}.metrics-grid{grid-template-columns:repeat(2,1fr)}.action-area{padding:2.5rem 1.5rem}.primary-action-button{padding:1rem 2.5rem;font-size:1rem;width:100%;justify-content:center}.secondary-action-button{padding:1.25rem 3rem;font-size:1.1rem;width:100%;justify-content:center}}@media(max-width:480px){.page-header{padding:.75rem 1rem}.header-engine-text{display:none}.content-container{padding:2rem 1rem}.hero-section{margin-bottom:2.5rem}.hero-title{font-size:1.75rem}.hero-description{font-size:.95rem}.metrics-grid{grid-template-columns:1fr}.action-area{padding:2rem 1rem}.modal-window{padding:2rem 1.5rem!important}}.confirmation-modal-overlay{position:fixed;inset:0;background-color:#0f172a99;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem;animation:fadeIn .2s ease-out}.confirmation-modal-container{background:#fff;border-radius:16px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;width:100%;max-width:450px;overflow:hidden;animation:slideIn .3s cubic-bezier(.16,1,.3,1);border:1px solid #E2E8F0}.confirmation-modal-header{padding:1.5rem 1.5rem 1rem;display:flex;align-items:flex-start;gap:1rem}.confirmation-icon-wrapper{flex-shrink:0;width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center}.confirmation-icon-wrapper.danger{background-color:#fef2f2;color:#ef4444}.confirmation-icon-wrapper.warning{background-color:#fffbeb;color:#f59e0b}.confirmation-icon-wrapper.info{background-color:#eff6ff;color:#3b82f6}.confirmation-text-content h3{margin:0 0 .5rem;font-size:1.125rem;font-weight:600;color:#0f172a}.confirmation-text-content p{margin:0;color:#64748b;font-size:.875rem;line-height:1.5}.confirmation-modal-footer{padding:1rem 1.5rem 1.5rem;display:flex;justify-content:flex-end;gap:.75rem;background-color:#f8fafc;border-top:1px solid #F1F5F9}.modal-btn{padding:.625rem 1rem;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;border:1px solid transparent}.modal-btn.cancel{background-color:#fff;border-color:#e2e8f0;color:#475569}.modal-btn.cancel:hover{background-color:#f1f5f9;border-color:#cbd5e1}.modal-btn.confirm{color:#fff;box-shadow:0 1px 2px #0000000d}.modal-btn.confirm.danger{background-color:#ef4444;border-color:#ef4444}.modal-btn.confirm.danger:hover{background-color:#dc2626}.modal-btn.confirm.warning{background-color:#f59e0b;border-color:#f59e0b}.modal-btn.confirm.warning:hover{background-color:#d97706}.modal-btn.confirm.info{background-color:#3b82f6;border-color:#3b82f6}.modal-btn.confirm.info:hover{background-color:#2563eb}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.face-thumbnail{position:relative;display:flex;flex-direction:column;border-radius:4px;overflow:hidden;box-shadow:none;margin:0;transition:all .3s cubic-bezier(.25,.8,.25,1);cursor:pointer;width:100%;height:100%;background:#f0f0f0}.face-thumbnail:hover{opacity:.9}.face-container{position:relative;display:flex;justify-content:center;align-items:center;height:100%;width:100%;background-color:#f5f5f5;overflow:hidden}.face-crop{background-repeat:no-repeat;transform-origin:top left}.face-loading{display:flex;justify-content:center;align-items:center;width:100%;height:100%;background-color:#f0f0f0;color:#666}.face-error{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%;background-color:#f8d7da;color:#721c24}.face-error span{font-size:24px}.face-error small{font-size:10px}.face-debug{position:absolute;bottom:0;left:0;right:0;background-color:#000000b3;color:#fff;font-size:8px;padding:4px;display:flex;flex-direction:column}.face-debug small{margin:1px 0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.confidence-indicator{display:none;height:0;width:0;margin:0}.confidence-bar{height:100%;background-color:#4caf50}.cluster-card{background:#fff;border:1.5px solid #FED7AA;border-radius:20px;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;display:flex;flex-direction:column;height:100%;overflow:hidden;box-shadow:0 4px 6px -1px #f973160d}.cluster-card:hover{transform:translateY(-6px);box-shadow:0 20px 25px -5px #f9731626}.cluster-card-image-container{aspect-ratio:1;width:100%;background:#fff7ed;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative;border-bottom:1.2px solid #FED7AA}.cluster-card-info{padding:1rem;display:flex;flex-direction:column;flex:1}.photo-count-badge{position:absolute;bottom:.75rem;right:.75rem;background:#f97316e6;color:#fff;padding:.3rem .8rem;border-radius:100px;font-size:.75rem;font-weight:800;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 4px 6px #f9731633;text-transform:uppercase;letter-spacing:.04em;z-index:10}.cluster-name-title{margin:0;font-size:1rem;font-weight:800;color:#1e293b;line-height:1.3;word-break:break-word;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;font-family:Outfit,sans-serif}@media(max-width:480px){.cluster-card-info{padding:.75rem}.cluster-name-title{font-size:.9rem}.photo-count-badge{font-size:.65rem;padding:.2rem .6rem}}.cluster-grid-page{min-height:100dvh;width:100%;background-color:#fff;background-image:radial-gradient(#FED7AA 1px,transparent 1px);background-size:32px 32px;color:#1e293b;font-family:Inter,-apple-system,sans-serif;display:flex;flex-direction:column;position:relative}.cluster-grid-header{padding:1.5rem 2.5rem;border-bottom:1.5px solid #FED7AA;background-color:#ffffffe6;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between}.cluster-grid-container{padding:3rem 2rem;max-width:1400px;margin:0 auto;width:100%;flex:1}.filter-controls{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:2rem;margin-bottom:3rem;background:#fff;border:1.5px solid #FED7AA;padding:1.25rem;border-radius:20px;box-shadow:0 10px 25px -5px #f973160d}.search-input-wrapper{flex:1;min-width:300px;position:relative}.sort-controls{display:flex;align-items:center;gap:1.25rem}.clusters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;width:100%}@media(max-width:1024px){.clusters-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.cluster-grid-header{padding:.9rem 1.25rem}.header-right-stats{width:auto;flex-shrink:0}.cluster-grid-container{padding:1.5rem 1rem}.filter-controls{gap:1rem;padding:1rem}.search-input-wrapper{min-width:0;flex:1}.sort-controls{width:100%;justify-content:space-between}.clusters-grid{grid-template-columns:repeat(2,1fr);gap:1rem}}@media(max-width:600px){.filter-controls{flex-direction:column;gap:.75rem}.search-input-wrapper{min-width:100%;width:100%}.sort-controls{width:100%;justify-content:space-between}}@media(max-width:480px){.cluster-grid-header{padding:.7rem 1rem}.header-logo-group{flex:1;min-width:0}.header-title-group{display:block}.header-right-stats{font-size:.72rem!important;padding:.4rem .75rem!important}.clusters-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}.sort-controls{flex-direction:column;align-items:flex-start;gap:.5rem}.sort-select-wrapper{width:100%}.sort-select-wrapper select{width:100%!important;min-width:0!important}}@media(max-width:360px){.clusters-grid{grid-template-columns:1fr}}
