@keyframes fadeIn { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } } #start h1 { animation: fadeIn 0.8s ease-out; } #start p { animation: fadeIn 0.8s ease-out 0.2s both; } #start .subtitle { animation: fadeIn 0.8s ease-out 0.4s both; } #start button { animation: fadeIn 0.8s ease-out 0.6s both; } #start { position: fixed; inset: 0; top: 70px; /* Account for nav bar */ background: transparent; background-attachment: fixed; color: #e8eef5; display: flex; flex-direction: column; align-items: center; justify-content: center; font-size: 18px; z-index: 500; text-align: center; padding: 40px 20px; pointer-events: auto; } #start.hidden { display: none !important; visibility: hidden !important; opacity: 0 !important; pointer-events: none !important; z-index: -9999 !important; position: fixed !important; top: -9999px !important; left: -9999px !important; width: 0 !important; height: 0 !important; overflow: hidden !important; } #start.hidden, #start.hidden *, #start.hidden h1, #start.hidden p, #start.hidden button, #start.hidden div { display: none !important; visibility: hidden !important; opacity: 0 !important; pointer-events: none !important; position: absolute !important; top: -9999px !important; left: -9999px !important; width: 0 !important; height: 0 !important; overflow: hidden !important; clip: rect(0, 0, 0, 0) !important; } #start h1 { margin-bottom: 28px; font-size: 6rem; font-weight: 200; letter-spacing: 4px; position: relative; z-index: 2; color: #ffffff; text-shadow: 0 4px 20px rgba(0, 0, 0, 0.5); line-height: 1.2; font-family: 'Birthstone', cursive; } #start p { margin-bottom: 48px; opacity: 0.95; font-size: 1.25rem; font-weight: 300; max-width: 600px; line-height: 1.7; color: rgba(255, 255, 255, 0.95); text-shadow: 0 2px 8px rgba(0, 0, 0, 0.3); letter-spacing: 0.5px; } #start .subtitle { margin-bottom: 72px; opacity: 0.9; font-size: 1rem; font-weight: 300; color: rgba(255, 255, 255, 0.85); text-shadow: 0 2px 8px rgba(0, 0, 0, 0.3); letter-spacing: 1px; text-transform: uppercase; } #start button { background: linear-gradient(135deg, #ffffff 0%, #f5f5f5 100%) !important; background-color: #ffffff !important; color: #1a1a3e !important; border: none !important; padding: 22px 60px; font-size: 18px; font-weight: 600; font-family: 'Playfair Display', serif; border-radius: 50px; cursor: pointer !important; transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1); box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3), 0 0 0 0 rgba(255, 255, 255, 0.4); letter-spacing: 1px; position: relative; z-index: 600 !important; overflow: hidden; visibility: visible !important; display: block !important; opacity: 1 !important; pointer-events: auto !important; } #start button::before { content: ''; position: absolute; top: 50%; left: 50%; width: 0; height: 0; border-radius: 50%; background: rgba(255, 255, 255, 0.3); transform: translate(-50%, -50%); transition: width 0.6s ease, height 0.6s ease; } #start button:hover:not(:disabled)::before { width: 300px; height: 300px; } #start button:hover:not(:disabled) { transform: translateY(-4px) scale(1.02); background: linear-gradient(135deg, #ffffff 0%, #ffffff 100%) !important; box-shadow: 0 12px 40px rgba(0, 0, 0, 0.4), 0 0 0 4px rgba(255, 255, 255, 0.1); } #start button:disabled { background: rgba(255, 255, 255, 0.5) !important; opacity: 0.6; cursor: not-allowed; } #start button:active:not(:disabled) { transform: translateY(-2px) scale(0.98); } .marker-info { display: none; /* Hide technical info from clients */ } #markerInfoContainer { display: none; /* Hide the container entirely */ } #loading { position: fixed; inset: 0; background: rgba(26, 26, 62, 0.95); color: #e8eef5; display: none; flex-direction: column; align-items: center; justify-content: center; font-size: 16px; z-index: 9; backdrop-filter: blur(10px); } #loading.active { display: flex; } .spinner { width: 50px; height: 50px; border: 3px solid rgba(232, 238, 245, 0.2); border-top-color: #9ecae1; border-radius: 50%; animation: spin 1s linear infinite; margin-bottom: 20px; } @keyframes spin { to { transform: rotate(360deg); } } #error { position: fixed; top: 20px; left: 50%; transform: translateX(-50%); background: #ff4466; color: white; padding: 15px 25px; border-radius: 12px; display: none; z-index: 20; max-width: 90%; text-align: center; font-size: 14px; box-shadow: 0 4px 20px rgba(255, 68, 102, 0.4); animation: slideDown 0.3s ease; } #error.active { display: block; } @keyframes slideDown { from { opacity: 0; transform: translateX(-50%) translateY(-20px); } to { opacity: 1; transform: translateX(-50%) translateY(0); } } #errorActions button:hover { transform: translateY(-2px); box-shadow: 0 4px 12px rgba(0,0,0,0.3); } #arStatus { animation: fadeIn 0.3s ease; } #arStatus.detecting { background: rgba(107, 174, 214, 0.9); } #arStatus.detected { background: rgba(0, 200, 100, 0.9); } #debug { display: none; /* Hide debug info from clients */ } #no-markers { background: rgba(255, 68, 102, 0.1); border: 1px solid rgba(255, 68, 102, 0.3); border-radius: 12px; padding: 20px; margin-bottom: 20px; max-width: 350px; } #no-markers a { color: #6BAED6; text-decoration: none; } #no-markers a:hover { text-decoration: underline; } a-scene { position: fixed !important; top: 0 !important; left: 0 !important; width: 100vw !important; height: 100vh !important; z-index: 1 !important; } /* Full screen AR on mobile */ @media (max-width: 768px) { body.ar-active { position: fixed !important; width: 100vw !important; height: 100vh !important; height: 100dvh !important; /* Dynamic viewport height for mobile */ overflow: hidden !important; padding: 0 !important; margin: 0 !important; background: #000000 !important; background-color: #000000 !important; background-image: none !important; } body.ar-active.aurora-bg { background: #000000 !important; background-color: #000000 !important; background-image: none !important; } body.ar-active .top-nav, body.ar-active nav { display: none !important; } body.ar-active #stars-canvas-root { display: none !important; visibility: hidden !important; opacity: 0 !important; } body.ar-active a-scene { position: fixed !important; top: 0 !important; left: 0 !important; width: 100vw !important; width: 100dvw !important; /* Dynamic viewport width for mobile */ height: 100vh !important; height: 100dvh !important; /* Dynamic viewport height for mobile */ z-index: 9999 !important; background: transparent !important; } body.ar-active #start { display: none !important; } } a-scene[style*="display: none"], a-scene[style*="display:none"] { position: fixed !important; top: -9999px !important; left: -9999px !important; width: 0 !important; height: 0 !important; z-index: -9999 !important; pointer-events: none !important; } /* Hide all canvas elements when AR is not active */ canvas.a-canvas[style*="display: none"], canvas.a-canvas[style*="display:none"] { position: fixed !important; top: -9999px !important; left: -9999px !important; width: 0 !important; height: 0 !important; z-index: -9999 !important; pointer-events: none !important; visibility: hidden !important; opacity: 0 !important; } /* Hide AR UI elements (scanline, brackets, etc) when AR is not active */ .scanline, .scan-line, [class*="scan"], [class*="bracket"], [class*="corner"] { display: none !important; visibility: hidden !important; opacity: 0 !important; pointer-events: none !important; } #downloadButton { position: fixed; bottom: 30px; right: 30px; background: linear-gradient(135deg, #00ffaa 0%, #00cc88 100%); color: #0a0a0f; border: none; padding: 14px 28px; font-size: 15px; font-weight: 600; border-radius: 50px; cursor: pointer; z-index: 100; display: none; box-shadow: 0 4px 15px rgba(0, 255, 170, 0.4); transition: transform 0.2s, box-shadow 0.2s; } #downloadButton:hover { transform: translateY(-2px); box-shadow: 0 6px 20px rgba(0, 255, 170, 0.6); } #downloadButton:active { transform: translateY(0); } #downloadButton svg { width: 18px; height: 18px; margin-right: 8px; vertical-align: middle; } .user-info { position: fixed; top: 20px; right: 20px; background: rgba(0, 0, 0, 0.7); color: white; padding: 12px 20px; border-radius: 12px; font-size: 13px; z-index: 15; display: flex; align-items: center; gap: 12px; } .user-info button { background: rgba(255, 68, 102, 0.2); border: 1px solid rgba(255, 68, 102, 0.5); color: #ff4466; padding: 6px 12px; border-radius: 6px; cursor: pointer; font-size: 12px; transition: all 0.2s; } .user-info button:hover { background: rgba(255, 68, 102, 0.3); } /* Logo moved to nav bar */ .logo { display: none; /* Hide old logo, now in nav */ } /* Enhanced text effects */ #start p, #start .subtitle { position: relative; z-index: 2; } /* Ensure proper layering */ #start { z-index: 10; } /* Smooth transitions for all interactive elements */ button, .logo { will-change: transform; } /* YouTube Player Container - Hidden */ #youtubePlayerContainer { position: fixed !important; top: -9999px !important; left: -9999px !important; width: 1px !important; height: 1px !important; opacity: 0 !important; pointer-events: none !important; visibility: hidden !important; z-index: -9999 !important; } /* Music Player UI */ #musicPlayer { position: fixed; bottom: 20px; right: 20px; background: rgba(0, 0, 0, 0.85); backdrop-filter: blur(20px); border-radius: 16px; padding: 16px; min-width: 280px; max-width: 320px; z-index: 1000; box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3); border: 1px solid rgba(255, 255, 255, 0.1); transition: opacity 0.3s ease, transform 0.3s ease; } #musicPlayer.hidden { opacity: 0; pointer-events: none; transform: translateY(20px); } /* Thank You Screen for Custom Frame Owners */ #thankYouScreen { position: fixed; inset: 0; background: rgba(0, 0, 0, 0.9); display: flex; align-items: center; justify-content: center; z-index: 10001; padding: 20px; } #thankYouScreen.hidden { display: none; } .thank-you-content { background: linear-gradient(135deg, #1a1a3e 0%, #2d3a5e 100%); border-radius: 24px; padding: 48px 40px; text-align: center; max-width: 420px; width: 100%; box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5); border: 1px solid rgba(255, 255, 255, 0.1); animation: thankYouFadeIn 0.5s ease-out; } @keyframes thankYouFadeIn { from { opacity: 0; transform: scale(0.9); } to { opacity: 1; transform: scale(1); } } .thank-you-icon { font-size: 64px; margin-bottom: 20px; } .thank-you-content h2 { color: #fff; font-size: 28px; margin-bottom: 16px; font-weight: 600; } .thank-you-content p { color: rgba(255, 255, 255, 0.85); font-size: 16px; margin-bottom: 8px; line-height: 1.6; } .thank-you-btn { background: linear-gradient(135deg, #6b8ca8 0%, #4a5f7a 100%); color: white; padding: 16px 48px; border-radius: 12px; border: none; font-weight: 600; font-size: 18px; cursor: pointer; margin-top: 24px; transition: transform 0.2s, box-shadow 0.2s; } .thank-you-btn:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(107, 140, 168, 0.4); } .music-player-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; } .music-player-title { color: #e8eef5; font-size: 14px; font-weight: 500; display: flex; align-items: center; gap: 8px; } .music-player-title::before { content: '🎵'; font-size: 16px; } .music-player-close { background: none; border: none; color: #e8eef5; font-size: 18px; cursor: pointer; padding: 4px; opacity: 0.7; transition: opacity 0.2s; line-height: 1; } .music-player-close:hover { opacity: 1; } .music-player-controls { display: flex; align-items: center; gap: 12px; margin-bottom: 12px; } .music-player-btn { background: rgba(255, 255, 255, 0.1); border: 1px solid rgba(255, 255, 255, 0.2); color: #e8eef5; border-radius: 8px; width: 40px; height: 40px; display: flex; align-items: center; justify-content: center; cursor: pointer; transition: all 0.2s ease; font-size: 18px; padding: 0; } .music-player-btn:hover { background: rgba(255, 255, 255, 0.2); transform: scale(1.05); } .music-player-btn:active { transform: scale(0.95); } .music-player-volume { flex: 1; display: flex; align-items: center; gap: 8px; } .music-player-volume-icon { color: #e8eef5; font-size: 16px; opacity: 0.8; } .music-player-volume-slider { flex: 1; height: 4px; background: rgba(255, 255, 255, 0.2); border-radius: 2px; outline: none; -webkit-appearance: none; appearance: none; } .music-player-volume-slider::-webkit-slider-thumb { -webkit-appearance: none; appearance: none; width: 14px; height: 14px; background: #e8eef5; border-radius: 50%; cursor: pointer; transition: transform 0.2s; } .music-player-volume-slider::-webkit-slider-thumb:hover { transform: scale(1.2); } .music-player-volume-slider::-moz-range-thumb { width: 14px; height: 14px; background: #e8eef5; border-radius: 50%; cursor: pointer; border: none; transition: transform 0.2s; } .music-player-volume-slider::-moz-range-thumb:hover { transform: scale(1.2); } .music-player-status { font-size: 12px; color: rgba(232, 238, 245, 0.7); text-align: center; margin-top: 8px; } /* Music Player Toggle Button (when player is hidden) */ #musicPlayerToggle { position: fixed; bottom: 20px; right: 20px; background: rgba(0, 0, 0, 0.85); backdrop-filter: blur(20px); border-radius: 50%; width: 56px; height: 56px; display: none; align-items: center; justify-content: center; cursor: pointer; z-index: 999; box-shadow: 0 4px 16px rgba(0, 0, 0, 0.3); border: 1px solid rgba(255, 255, 255, 0.1); transition: all 0.3s ease; } #musicPlayerToggle:hover { background: rgba(0, 0, 0, 0.95); transform: scale(1.1); } #musicPlayerToggle.visible { display: flex; } #musicPlayerToggle::before { content: '🎵'; font-size: 24px; } @media (max-width: 768px) { #musicPlayer { bottom: 10px; right: 10px; left: 10px; min-width: auto; max-width: none; } #musicPlayerToggle { bottom: 10px; right: 10px; width: 48px; height: 48px; } } /* Content Sections - Professional Layout */ .content-sections { position: relative; z-index: 1; background: linear-gradient(180deg, rgba(26, 26, 62, 0) 0%, #0f0f23 5%, #1a1a3e 100%); margin-top: 0; min-height: calc(100vh - 60px); padding: 60px 20px 100px 20px; width: 100%; max-width: 100%; box-sizing: border-box; display: none; margin-left: 0; margin-right: 0; clear: both; overflow-x: hidden; pointer-events: auto; } .content-sections.active { display: block; } .section { max-width: 1200px; margin: 0 auto; padding: 80px 20px; opacity: 0; transform: translateY(50px); transition: opacity 0.8s ease, transform 0.8s ease; } .section.visible { opacity: 1; transform: translateY(0); } .section-title { font-size: 3.5rem; font-weight: 300; color: #ffffff; text-align: center; margin-bottom: 24px; letter-spacing: 3px; text-shadow: 0 4px 20px rgba(0, 0, 0, 0.5); line-height: 1.2; } .section-subtitle { font-size: 1.3rem; color: rgba(255, 255, 255, 0.9); text-align: center; margin-bottom: 80px; font-weight: 300; max-width: 700px; margin-left: auto; margin-right: auto; line-height: 1.7; letter-spacing: 0.5px; } .content-card { background: rgba(255, 255, 255, 0.06); backdrop-filter: blur(20px) saturate(180%); -webkit-backdrop-filter: blur(20px) saturate(180%); border: 1px solid rgba(255, 255, 255, 0.12); border-radius: 24px; padding: 48px; margin: 40px 0; transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1); box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3); } .content-card:hover { transform: translateY(-8px); box-shadow: 0 16px 48px rgba(0, 0, 0, 0.4); border-color: rgba(158, 202, 225, 0.3); background: rgba(255, 255, 255, 0.08); } .content-card h3 { font-size: 2.2rem; color: #ffffff; margin-bottom: 20px; font-weight: 400; letter-spacing: 1px; line-height: 1.3; } .content-card p { color: rgba(255, 255, 255, 0.9); line-height: 1.9; font-size: 1.15rem; margin-bottom: 20px; font-weight: 300; letter-spacing: 0.2px; } .content-card p strong { color: #9ecae1; font-weight: 500; } .timeline { position: relative; padding: 40px 0; } .timeline-item { position: relative; padding-left: 60px; margin-bottom: 50px; opacity: 0; transform: translateX(-30px); transition: opacity 0.6s ease, transform 0.6s ease; } .timeline-item.visible { opacity: 1; transform: translateX(0); } .timeline-item::before { content: ''; position: absolute; left: 0; top: 0; width: 20px; height: 20px; background: #9ecae1; border-radius: 50%; border: 3px solid #1a1a3e; box-shadow: 0 0 20px rgba(158, 202, 225, 0.5); } .timeline-item::after { content: ''; position: absolute; left: 9px; top: 20px; width: 2px; height: calc(100% + 30px); background: rgba(158, 202, 225, 0.3); } .timeline-item:last-child::after { display: none; } .timeline-content { background: rgba(255, 255, 255, 0.05); padding: 25px; border-radius: 15px; border-left: 3px solid #9ecae1; } .timeline-content h4 { color: #9ecae1; font-size: 1.4rem; margin-bottom: 10px; font-weight: 400; } .timeline-content p { color: rgba(255, 255, 255, 0.8); line-height: 1.7; } .gallery-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 30px; margin-top: 40px; } .gallery-item { position: relative; aspect-ratio: 4/3; border-radius: 15px; overflow: hidden; cursor: pointer; transition: transform 0.3s ease; background: rgba(255, 255, 255, 0.05); border: 1px solid rgba(255, 255, 255, 0.1); } .gallery-item:hover { transform: scale(1.05); } .gallery-item img { width: 100%; height: 100%; object-fit: cover; opacity: 0.8; transition: opacity 0.3s ease; } .gallery-item:hover img { opacity: 1; } .gallery-item .overlay { position: absolute; bottom: 0; left: 0; right: 0; background: linear-gradient(to top, rgba(0, 0, 0, 0.8), transparent); padding: 20px; color: white; } .stats-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 30px; margin: 40px 0; } .stat-card { text-align: center; padding: 30px; background: rgba(255, 255, 255, 0.05); border-radius: 15px; border: 1px solid rgba(255, 255, 255, 0.1); } .stat-number { font-size: 3rem; color: #9ecae1; font-weight: 300; margin-bottom: 10px; } .stat-label { color: rgba(255, 255, 255, 0.7); font-size: 1rem; text-transform: uppercase; letter-spacing: 1px; } .testimonial-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 30px; margin-top: 40px; } .testimonial-card { background: rgba(255, 255, 255, 0.05); padding: 30px; border-radius: 15px; border-left: 4px solid #9ecae1; } .testimonial-text { color: rgba(255, 255, 255, 0.9); font-style: italic; line-height: 1.8; margin-bottom: 20px; font-size: 1.1rem; } .testimonial-author { color: #9ecae1; font-weight: 500; } .accordion { margin: 20px 0; } .accordion-item { background: rgba(255, 255, 255, 0.05); border: 1px solid rgba(255, 255, 255, 0.1); border-radius: 10px; margin-bottom: 15px; overflow: hidden; } .accordion-header { padding: 20px; cursor: pointer; display: flex; justify-content: space-between; align-items: center; color: white; font-size: 1.2rem; transition: background 0.3s ease; } .accordion-header:hover { background: rgba(255, 255, 255, 0.1); } .accordion-content { max-height: 0; overflow: hidden; transition: max-height 0.3s ease; padding: 0 20px; } .accordion-item.active .accordion-content { max-height: 500px; padding: 20px; } .accordion-icon { transition: transform 0.3s ease; } .accordion-item.active .accordion-icon { transform: rotate(180deg); } /* Top Navigation Bar - Compact Professional Design */ .top-nav { position: fixed; top: 0; left: 0; right: 0; width: 100%; background: rgba(15, 15, 35, 0.98); backdrop-filter: blur(20px) saturate(180%); -webkit-backdrop-filter: blur(20px) saturate(180%); border-bottom: 1px solid rgba(255, 255, 255, 0.08); z-index: 1000; padding: 12px 24px; display: flex; align-items: center; justify-content: space-between; box-shadow: 0 2px 16px rgba(0, 0, 0, 0.3); transition: all 0.3s ease; box-sizing: border-box; } .nav-logo { max-width: 100px; max-height: 36px; height: auto; transition: transform 0.3s ease; flex-shrink: 0; display: flex; align-items: center; overflow: hidden; } .nav-logo:hover { transform: scale(1.05); } .nav-logo img { width: auto; height: 100%; max-height: 36px; max-width: 100px; object-fit: contain; display: block; filter: drop-shadow(0 2px 8px rgba(0, 0, 0, 0.3)); } .nav-tabs { display: flex; gap: 4px; align-items: center; flex-wrap: nowrap; flex-shrink: 1; } .nav-right-items { display: flex; flex-direction: row; gap: 8px; align-items: center; margin-left: 8px; } .nav-tab-btn { background: transparent; border: 1px solid transparent; color: rgba(255, 255, 255, 0.85); padding: 8px 16px; border-radius: 6px; font-family: 'Playfair Display', serif !important; cursor: pointer; font-size: 14px; font-weight: 500; letter-spacing: 0.2px; transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1); text-decoration: none; display: inline-block; position: relative; overflow: hidden; white-space: nowrap; } .nav-tab-btn::before { content: ''; position: absolute; top: 0; left: -100%; width: 100%; height: 100%; background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.1), transparent); transition: left 0.5s ease; } .nav-tab-btn:hover::before { left: 100%; } .nav-tab-btn:hover { background: rgba(255, 255, 255, 0.08); border-color: rgba(255, 255, 255, 0.15); color: #ffffff; transform: translateY(-1px); } .nav-tab-btn.active { background: linear-gradient(135deg, rgba(158, 202, 225, 0.2), rgba(107, 174, 214, 0.15)); border-color: rgba(158, 202, 225, 0.4); color: #9ecae1; box-shadow: 0 2px 12px rgba(158, 202, 225, 0.2); } /* Prevent zoom gestures but allow scrolling */ html { overflow-x: hidden; position: relative; height: auto; min-height: 100%; touch-action: pan-y; /* Allow vertical scrolling, prevent zoom */ } body { padding-top: 70px; overflow-x: hidden; overflow-y: auto; width: 100%; max-width: 100vw; position: relative; min-height: 100vh; touch-action: pan-y; /* Allow vertical scrolling, prevent zoom */ } /* Prevent zoom on inputs but allow interaction */ input, textarea, select { font-size: 16px !important; /* Prevents zoom on iOS */ } /* Prevent double-tap zoom on buttons and links */ button, a { touch-action: manipulation; } /* Tab Content - Professional Styling */ .tabs { display: none; /* Hide old tabs */ } .tab-content { display: none !important; max-width: 900px; width: 100%; margin: 0 auto; padding: 60px 40px; animation: fadeInUp 0.6s ease-out; box-sizing: border-box; position: relative; clear: both; z-index: 10; pointer-events: auto; } .tab-content.active { display: block !important; } @keyframes fadeInUp { from { opacity: 0; transform: translateY(30px); } to { opacity: 1; transform: translateY(0); } } .tab-content h3 { color: #ffffff; margin-bottom: 32px; font-size: 2.5rem; font-weight: 300; letter-spacing: 2px; text-align: center; text-shadow: 0 2px 12px rgba(0, 0, 0, 0.4); line-height: 1.3; } .tab-content p { color: rgba(255, 255, 255, 0.92); line-height: 1.9; margin-bottom: 24px; font-size: 1.15rem; font-weight: 300; letter-spacing: 0.3px; } .tab-content p strong { color: #9ecae1; font-weight: 500; letter-spacing: 0.5px; } @media (max-width: 768px) { /* Mobile Navigation */ .top-nav { padding: 8px 10px; flex-wrap: nowrap; min-height: 48px; height: 48px; overflow-x: auto; -webkit-overflow-scrolling: touch; position: fixed; top: 0; left: 0; right: 0; z-index: 1000; width: 100%; box-sizing: border-box; } .nav-logo { max-width: 70px; max-height: 28px; height: 28px; margin-right: 6px; flex-shrink: 0; display: flex; align-items: center; overflow: hidden; } .nav-logo img { max-height: 28px; max-width: 70px; width: auto; height: auto; object-fit: contain; } .nav-tabs { gap: 3px; flex: 0 0 auto; justify-content: flex-end; min-width: 0; display: flex; } .nav-tab-btn { padding: 6px 8px; font-size: 10px; letter-spacing: 0; flex-shrink: 0; white-space: nowrap; min-width: fit-content; } .nav-right-items { margin-left: 4px; gap: 6px; flex-direction: row; } /* Shorten text on mobile */ .nav-tab-btn[data-tab="how"]::after { content: ''; } body { padding-top: 48px; overflow-x: hidden; position: relative; min-height: 100vh; height: auto; } html { overflow-x: hidden; position: relative; height: 100%; } /* Mobile Start Section */ #start h1 { font-size: 3.5rem; letter-spacing: 2px; margin-bottom: 20px; } #start p { font-size: 1rem; max-width: 90%; margin-bottom: 32px; } #start .subtitle { font-size: 0.85rem; margin-bottom: 48px; } #start button { padding: 18px 40px; font-size: 16px; width: 90%; max-width: 300px; } /* Ensure proper spacing between buttons */ #start { padding-bottom: 60px; min-height: calc(100vh - 48px); box-sizing: border-box; overflow-y: auto; -webkit-overflow-scrolling: touch; } /* Mobile Content Sections */ .section-title { font-size: 2rem; } .content-card { padding: 25px 20px; margin: 20px 0; } .content-card h3 { font-size: 1.8rem; } .content-card p { font-size: 1rem; line-height: 1.7; } .tab-content { padding: 40px 20px; } .tab-content h3 { font-size: 2rem; margin-bottom: 24px; } .tab-content p { font-size: 1rem; line-height: 1.7; } .content-sections { padding: 40px 0 80px 0; } .gallery-grid, .testimonial-grid { grid-template-columns: 1fr; } .tab-btn { padding: 10px 16px; font-size: 14px; } } @media (max-width: 480px) { /* Extra small mobile */ .nav-tab-btn { padding: 6px 8px; font-size: 10px; } .nav-logo { max-width: 70px; max-height: 26px; } #start h1 { font-size: 2.8rem; letter-spacing: 1px; } #start button { padding: 16px 32px; font-size: 15px; } }

Welcome to Your Crafted Frame

Experience your photo frame come to life with augmented reality

Point your camera at your frame to begin

Preparing your experience...