/* AegisSight Monitor - Product Page v2 (Light Mode) */ /* Fonts */ @font-face { font-family:'Inter'; src:url('/assets/fonts/Inter-Regular.woff2') format('woff2'),url('/assets/fonts/Inter-Regular.ttf') format('truetype'); font-weight:400; font-display:swap; } @font-face { font-family:'Inter'; src:url('/assets/fonts/Inter-SemiBold.woff2') format('woff2'),url('/assets/fonts/Inter-SemiBold.ttf') format('truetype'); font-weight:600; font-display:swap; } @font-face { font-family:'Inter'; src:url('/assets/fonts/Inter-Bold.woff2') format('woff2'),url('/assets/fonts/Inter-Bold.ttf') format('truetype'); font-weight:700; font-display:swap; } @font-face { font-family:'Inter'; src:url('/assets/fonts/Inter-Light.woff2') format('woff2'),url('/assets/fonts/Inter-Light.ttf') format('truetype'); font-weight:300; font-display:swap; } :root { --navy: #0A1832; --navy-light: #132844; --gold: #C8A851; --gold-light: #D4B96A; --gold-dark: #B39645; --white: #FAFBFD; --base: #F5F7FA; --alt: #EDF0F5; --alt-solid: #F0F3F7; --gray-100: #E4E8EE; --gray-200: #D0D5DE; --gray-400: #9AA5B4; --gray-600: #5A6478; --text: #2A2F3A; --text-light: #5A6478; --radius: 8px; --radius-lg: 12px; --shadow: 0 2px 12px rgba(10,24,50,0.06); --shadow-lg: 0 8px 32px rgba(10,24,50,0.1); --nav-height: 72px; } *,*::before,*::after { margin:0; padding:0; box-sizing:border-box; } html { scroll-behavior:smooth; scroll-padding-top:var(--nav-height); } body { font-family:'Inter',system-ui,-apple-system,sans-serif; font-size:16px; line-height:1.6; color:var(--text); background:var(--base); -webkit-font-smoothing:antialiased; } img { max-width:100%; height:auto; } a { color:inherit; text-decoration:none; } .container { max-width:1120px; margin:0 auto; padding:0 24px; } /* ==================== NAV ==================== */ .navbar { position:fixed; top:0; left:0; right:0; height:var(--nav-height); background:rgba(250,251,253,0.92); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px); z-index:1000; transition:box-shadow 0.3s; } .navbar.scrolled { box-shadow:0 1px 16px rgba(10,24,50,0.08); } .nav-container { max-width:1120px; margin:0 auto; padding:0 24px; height:100%; display:flex; align-items:center; justify-content:space-between; } .nav-logo { display:flex; align-items:center; } .logo-img { height:36px; width:auto; } .nav-menu { list-style:none; display:flex; gap:32px; } .nav-menu a { font-size:0.9rem; font-weight:500; color:var(--navy); transition:color 0.2s; } .nav-menu a:hover { color:var(--gold); } .mobile-menu-toggle { display:none; background:none; border:none; cursor:pointer; width:32px; height:24px; position:relative; flex-direction:column; justify-content:space-between; } .mobile-menu-toggle span { display:block; width:100%; height:2px; background:var(--navy); border-radius:2px; transition:transform 0.3s,opacity 0.3s; } .mobile-menu-toggle.active span:nth-child(1) { transform:rotate(45deg) translate(7px,7px); } .mobile-menu-toggle.active span:nth-child(2) { opacity:0; } .mobile-menu-toggle.active span:nth-child(3) { transform:rotate(-45deg) translate(7px,-7px); } .mobile-menu { position:fixed; top:var(--nav-height); left:0; right:0; background:var(--white); padding:16px 24px 24px; box-shadow:var(--shadow-lg); transform:translateY(-100%); opacity:0; transition:transform 0.3s,opacity 0.3s; z-index:999; pointer-events:none; } .mobile-menu.open { transform:translateY(0); opacity:1; pointer-events:all; } .mobile-menu ul { list-style:none; } .mobile-menu li { border-bottom:1px solid var(--gray-100); } .mobile-menu a { display:block; padding:14px 0; font-size:1rem; font-weight:500; color:var(--navy); } .mobile-overlay { position:fixed; inset:0; background:rgba(10,24,50,0.3); z-index:998; opacity:0; pointer-events:none; transition:opacity 0.3s; } .mobile-overlay.open { opacity:1; pointer-events:all; } /* ==================== HERO ==================== */ .hero { position:relative; min-height:88vh; display:flex; align-items:center; padding-top:var(--nav-height); overflow:hidden; background:var(--navy); } .hero-video-container { position:absolute; inset:0; z-index:0; } .hero-video { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:0; transition:opacity 3s ease; } .hero-video.active { opacity:1; } .hero-overlay { position:absolute; inset:0; background:linear-gradient(135deg,rgba(10,24,50,0.82) 0%,rgba(10,24,50,0.65) 50%,rgba(10,24,50,0.75) 100%); z-index:1; } .hero-content { position:relative; z-index:2; max-width:700px; padding:80px 24px; color:var(--white); } .hero-title { font-size:3.4rem; font-weight:700; line-height:1.1; margin-bottom:20px; letter-spacing:-0.02em; color:var(--white); } .hero-claim { font-size:1.45rem; font-weight:300; line-height:1.5; margin-bottom:16px; color:rgba(255,255,255,0.9); } .gold { color:var(--gold); font-weight:600; } .hero-sub { font-size:1.05rem; color:rgba(255,255,255,0.65); line-height:1.7; margin-bottom:36px; } .hero-cta { display:flex; gap:16px; flex-wrap:wrap; } /* ==================== BUTTONS ==================== */ .btn { display:inline-flex; align-items:center; justify-content:center; padding:12px 28px; border-radius:var(--radius); font-family:inherit; font-size:0.95rem; font-weight:600; cursor:pointer; transition:all 0.2s; border:2px solid transparent; text-decoration:none; } .btn-primary { background:var(--gold); color:var(--navy); border-color:var(--gold); } .btn-primary:hover { background:var(--gold-dark); border-color:var(--gold-dark); } .btn-outline-light { background:transparent; color:var(--white); border-color:rgba(255,255,255,0.4); } .btn-outline-light:hover { background:rgba(255,255,255,0.1); border-color:var(--white); } .btn-outline { background:transparent; color:var(--navy); border-color:var(--navy); } .btn-outline:hover { background:var(--navy); color:var(--white); } .btn-lg { padding:16px 40px; font-size:1.05rem; } .btn-block { width:100%; } /* ==================== SECTIONS ==================== */ .section { padding:88px 0; } .section-base { background:var(--base); } .section-alt { background:var(--alt-solid); } .section-dark { background:var(--navy); color:var(--white); } .section-title { font-size:2rem; font-weight:700; color:var(--navy); text-align:center; margin-bottom:16px; letter-spacing:-0.01em; } .section-dark .section-title { color:var(--white); } .section-subtitle { font-size:1.05rem; color:var(--text-light); text-align:center; max-width:600px; margin:0 auto 48px; } /* ==================== WAVE DIVIDERS ==================== */ .wave-divider { line-height:0; margin:0; overflow:hidden; } .wave-divider svg { display:block; width:100%; height:auto; } .wave-dark-to-light { background:var(--alt-solid); } .wave-alt-to-base { background:var(--base); } .wave-base-to-alt { background:var(--base); } .wave-base-to-dark { background:var(--base); } .wave-dark-to-base { background:var(--base); } /* ==================== GRID ==================== */ .grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; } .grid-4 { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; } /* ==================== PROBLEM ==================== */ .problem-card { text-align:center; padding:32px 20px; } .problem-icon { width:64px; height:64px; margin:0 auto 20px; display:flex; align-items:center; justify-content:center; background:var(--white); border-radius:50%; box-shadow:var(--shadow); } .problem-card h3 { font-size:1.1rem; font-weight:700; color:var(--navy); margin-bottom:10px; } .problem-card p { font-size:0.93rem; color:var(--text-light); line-height:1.6; } /* ==================== WORKFLOW ==================== */ .workflow { display:flex; align-items:flex-start; justify-content:center; margin-top:56px; } .workflow-step { flex:1; max-width:300px; text-align:center; padding:0 24px; } .step-number { width:48px; height:48px; margin:0 auto 20px; display:flex; align-items:center; justify-content:center; background:var(--gold); color:var(--navy); font-size:1.2rem; font-weight:700; border-radius:50%; } .workflow-step h3 { font-size:1.1rem; font-weight:700; color:var(--navy); margin-bottom:10px; } .workflow-step p { font-size:0.93rem; color:var(--text-light); line-height:1.6; } .workflow-connector { width:60px; height:2px; background:var(--gold); margin-top:23px; flex-shrink:0; opacity:0.4; } /* ==================== FEATURES ==================== */ .feature-card { background:var(--white); border-radius:var(--radius-lg); padding:28px 24px; box-shadow:var(--shadow); transition:box-shadow 0.3s,transform 0.3s; } .feature-card:hover { box-shadow:var(--shadow-lg); transform:translateY(-3px); } .feature-icon { width:48px; height:48px; display:flex; align-items:center; justify-content:center; background:var(--alt-solid); border-radius:var(--radius); margin-bottom:14px; } .feature-card h3 { font-size:1rem; font-weight:700; color:var(--navy); margin-bottom:8px; } .feature-card p { font-size:0.88rem; color:var(--text-light); line-height:1.6; } /* ==================== 3D CAROUSEL ==================== */ .carousel-viewport { perspective:1200px; overflow:visible; padding:40px 0 20px; } .carousel-track { display:flex; justify-content:center; align-items:center; position:relative; min-height:440px; } .carousel-card { width:380px; flex-shrink:0; background:var(--white); border-radius:var(--radius-lg); padding:28px 24px; box-shadow:var(--shadow); position:absolute; display:flex; flex-direction:column; transition:all 0.6s cubic-bezier(0.4,0,0.2,1); cursor:pointer; transform-style:preserve-3d; } .carousel-card.active { transform:scale(1) translateX(0) rotateY(0); z-index:3; opacity:1; pointer-events:all; } .carousel-card.left { transform:scale(0.78) translateX(-110%) rotateY(12deg); z-index:1; opacity:0.5; pointer-events:all; } .carousel-card.right { transform:scale(0.78) translateX(110%) rotateY(-12deg); z-index:1; opacity:0.5; pointer-events:all; } .carousel-card.hidden { transform:scale(0.6) translateX(0); z-index:0; opacity:0; pointer-events:none; } .carousel-nav { display:flex; justify-content:center; gap:10px; margin-top:24px; } .carousel-dot { width:10px; height:10px; border-radius:50%; border:2px solid var(--gold); background:transparent; cursor:pointer; transition:all 0.3s; padding:0; } .carousel-dot.active { background:var(--gold); } .card-live { border:2px solid var(--gold); box-shadow:0 4px 24px rgba(200,168,81,0.15); } .card-placeholder { border:2px dashed var(--gray-200); opacity:0.55; } .demo-badge { display:inline-block; padding:4px 14px; border-radius:20px; font-size:0.72rem; font-weight:700; letter-spacing:0.08em; text-transform:uppercase; margin-bottom:14px; width:fit-content; background:var(--gold); color:var(--navy); } .badge-soon { background:var(--gray-100); color:var(--gray-400); } .demo-title { font-size:1.25rem; font-weight:700; color:var(--navy); margin-bottom:16px; } .demo-stats { display:grid; grid-template-columns:repeat(3,1fr); gap:10px; margin-bottom:16px; } .demo-stat { text-align:center; padding:10px 6px; background:var(--alt-solid); border-radius:var(--radius); } .stat-value { display:block; font-size:1.4rem; font-weight:700; color:var(--navy); line-height:1.2; } .stat-label { display:block; font-size:0.72rem; color:var(--text-light); margin-top:3px; } .demo-excerpt { margin-bottom:16px; } .excerpt-text { font-size:0.88rem; color:var(--text); line-height:1.65; max-height:120px; overflow:hidden; position:relative; transition:max-height 0.4s ease; } .excerpt-text.expanded { max-height:600px; } .excerpt-text:not(.expanded)::after { content:''; position:absolute; bottom:0; left:0; right:0; height:40px; background:linear-gradient(transparent,var(--white)); } .excerpt-toggle { background:none; border:none; color:var(--gold); font-family:inherit; font-size:0.85rem; font-weight:600; cursor:pointer; padding:6px 0; } .excerpt-toggle:hover { color:var(--gold-dark); } .demo-updated { font-size:0.82rem; color:var(--text-light); margin-bottom:16px; } .placeholder-title { color:var(--gray-400); } .placeholder-text { font-size:0.95rem; color:var(--gray-400); flex:1; display:flex; align-items:center; justify-content:center; min-height:180px; } /* ==================== MAP ==================== */ .map-section { margin-top:48px; } .map-title { font-size:1.1rem; font-weight:600; color:var(--navy); margin-bottom:16px; text-align:center; } #map-container { height:420px; border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow); border:1px solid var(--gray-100); } /* Map pulse markers (exact lagebild style) */ .pulse-marker-wrapper { position:relative; width:20px; height:20px; } .pulse-marker-ring { position:absolute; inset:0; border-radius:50%; border:2px solid; animation:mapPulseRing 2s infinite; opacity:0; } .pulse-marker-ring:nth-child(2) { animation-delay:1s; } @keyframes mapPulseRing { 0%{transform:scale(0.5);opacity:0} 30%{opacity:0.6} 100%{transform:scale(2.5);opacity:0} } .pulse-marker-dot { position:absolute; top:50%; left:50%; width:8px; height:8px; margin:-4px 0 0 -4px; border-radius:50%; animation:pulseDot 2s infinite; } @keyframes pulseDot { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:0.5;transform:scale(0.7)} } /* Dark popup style */ .leaflet-popup-content-wrapper { background:#151D2E!important; color:#E8ECF4!important; border:1px solid #1E2D45!important; border-radius:4px!important; box-shadow:0 4px 16px rgba(0,0,0,0.4)!important; } .leaflet-popup-tip { background:#151D2E!important; } .leaflet-popup-content { margin:10px 14px!important; font-size:0.85rem!important; } /* ==================== TRUST ==================== */ .trust-grid { margin-top:48px; } .trust-card { text-align:center; padding:24px 16px; } .trust-icon-wrap { height:56px; display:flex; align-items:center; justify-content:center; margin-bottom:16px; } .trust-icon-wrap img { filter:brightness(0) invert(1); } .trust-icon-wrap.trust-flag img { filter:none; } .trust-card h3 { font-size:1.05rem; font-weight:700; margin-bottom:8px; } .trust-card p { font-size:0.88rem; opacity:0.7; line-height:1.5; } /* ==================== CTA ==================== */ .cta-container { text-align:center; max-width:600px; } .cta-text { font-size:1.1rem; color:var(--text-light); margin-bottom:32px; } .cta-email { font-size:0.9rem; color:var(--text-light); margin-top:16px; } /* ==================== FOOTER ==================== */ .footer { background:var(--navy); color:rgba(255,255,255,0.7); padding:40px 0; font-size:0.85rem; } .footer-content { display:flex; justify-content:space-between; align-items:center; margin-bottom:24px; padding-bottom:24px; border-bottom:1px solid rgba(255,255,255,0.1); } .footer-company { font-weight:600; color:var(--white); margin-bottom:4px; } .footer-links { display:flex; gap:24px; } .footer-links a { color:rgba(255,255,255,0.7); transition:color 0.2s; } .footer-links a:hover { color:var(--white); } .footer-copyright { text-align:center; font-size:0.8rem; opacity:0.5; } /* ==================== RESPONSIVE ==================== */ @media(max-width:1024px) { .grid-3 { grid-template-columns:repeat(2,1fr); } .grid-4 { grid-template-columns:repeat(2,1fr); } .hero-title { font-size:2.8rem; } .section { padding:64px 0; } .workflow-connector { width:40px; } } @media(max-width:768px) { .nav-menu { display:none; } .mobile-menu-toggle { display:flex; } .grid-3,.grid-4 { grid-template-columns:1fr; gap:20px; } .hero { min-height:75vh; } .hero-content { padding:48px 24px; } .hero-title { font-size:2.1rem; } .hero-claim { font-size:1.15rem; } .section { padding:48px 0; } .section-title { font-size:1.6rem; } .workflow { flex-direction:column; align-items:center; gap:8px; } .workflow-connector { width:2px; height:32px; margin:0; } .workflow-step { max-width:100%; padding:16px 0; } .hero-cta { flex-direction:column; } .hero-cta .btn { width:100%; } .footer-content { flex-direction:column; text-align:center; gap:16px; } #map-container { height:300px; } } @media(max-width:480px) { .hero-title { font-size:1.8rem; } .container { padding:0 16px; } }