Navy-Dreieck ragt von unten in den Hero hinein (negative margin), erzeugt sauberen spitzen Uebergang zwischen Video-Hero und dunkler Problem-Section. Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
274 Zeilen
18 KiB
CSS
274 Zeilen
18 KiB
CSS
/* 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:24px; color:rgba(255,255,255,0.9); }
|
|
.gold { color:var(--gold); font-weight:600; }
|
|
.hero-sub { font-size:0.95rem; color:rgba(255,255,255,0.55); 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-light); 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; }
|
|
|
|
/* ==================== SECTION DIVIDERS ==================== */
|
|
.divider { line-height:0; margin:0; overflow:hidden; }
|
|
.divider svg { display:block; width:100%; height:auto; }
|
|
.divider-chevron { background:var(--alt-solid); }
|
|
.divider-chevron-dark { background:var(--navy); }
|
|
.divider-chevron-into-hero { margin-top:-60px; position:relative; z-index:2; }
|
|
.divider-diagonal { background:var(--base); }
|
|
.divider-diagonal-dark { background:var(--base); }
|
|
.divider-gradient-alt-to-base { height:40px; background:linear-gradient(to bottom, var(--alt-solid), var(--base)); }
|
|
.divider-gradient-dark-to-base { height:80px; background:linear-gradient(to bottom, var(--navy), var(--base)); }
|
|
.divider-gradient-dark-to-alt { height:60px; background:linear-gradient(to bottom, var(--navy), var(--alt-solid)); }
|
|
|
|
/* ==================== 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; }
|
|
|
|
/* Problem dark variant */
|
|
.problem-card-dark { color:var(--white); }
|
|
.problem-card-dark h3 { color:var(--white); }
|
|
.problem-card-dark p { color:rgba(255,255,255,0.7); }
|
|
.problem-icon-dark { background:rgba(255,255,255,0.08); border:1px solid rgba(255,255,255,0.1); box-shadow:none; }
|
|
.problem-icon-dark img { filter:brightness(0) invert(1); }
|
|
|
|
/* ==================== 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; }
|
|
|
|
/* ==================== DEMOS SECTION ==================== */
|
|
#demos { padding-top:48px; }
|
|
|
|
/* ==================== LIVE STATS BAR ==================== */
|
|
.live-stats-bar { margin-bottom:40px; text-align:center; }
|
|
.live-stats-title { font-size:1rem; font-weight:600; color:var(--gold); text-transform:uppercase; letter-spacing:0.1em; margin-bottom:16px; }
|
|
.live-stats-row { display:flex; justify-content:center; gap:20px; flex-wrap:wrap; }
|
|
.live-stat { text-align:center; background:var(--white); border-radius:var(--radius-lg); padding:20px 32px; box-shadow:var(--shadow); border:1px solid var(--gray-100); min-width:160px; }
|
|
.live-stat-value { display:block; font-size:2.4rem; font-weight:700; color:var(--navy); line-height:1.1; letter-spacing:-0.02em; }
|
|
.live-stat-label { display:block; font-size:0.8rem; color:var(--text-light); text-transform:uppercase; letter-spacing:0.08em; margin-top:4px; }
|
|
|
|
/* ==================== FEATURE HIGHLIGHT ==================== */
|
|
.feature-statement { text-align:center; max-width:700px; margin:0 auto 48px; padding:0 24px; }
|
|
.feature-statement-text { font-size:1.6rem; font-weight:700; color:var(--navy); line-height:1.35; margin-bottom:12px; letter-spacing:-0.01em; }
|
|
.feature-statement-sub { font-size:1rem; color:var(--text-light); line-height:1.6; }
|
|
@media(max-width:768px) { .feature-statement-text { font-size:1.3rem; } }
|
|
|
|
/* ==================== 3D CAROUSEL ==================== */
|
|
.carousel-viewport { overflow-x:clip; overflow-y:visible; padding:20px 0; position:relative; }
|
|
.carousel-track { display:flex; justify-content:center; position:relative; }
|
|
.carousel-card { width:860px; 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 { position:relative; transform:none; z-index:3; opacity:1; }
|
|
.carousel-card.left { position:absolute; left:0; top:0; transform:scale(0.75) translateX(-70%); z-index:1; opacity:0.45; }
|
|
.carousel-card.right { position:absolute; right:0; top:0; transform:scale(0.75) translateX(70%); z-index:1; opacity:0.45; }
|
|
.carousel-card.hidden { position:absolute; transform:scale(0.5); z-index:0; opacity:0; pointer-events:none; }
|
|
|
|
/* Carousel arrows */
|
|
.carousel-arrow { position:absolute; top:50%; transform:translateY(-50%); z-index:10; width:44px; height:44px; border-radius:50%; border:2px solid var(--gray-200); background:var(--white); color:var(--navy); font-size:1.6rem; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:all 0.2s; box-shadow:var(--shadow); line-height:1; }
|
|
.carousel-arrow:hover { border-color:var(--gold); color:var(--gold); box-shadow:var(--shadow-lg); }
|
|
.carousel-prev { left:8px; }
|
|
.carousel-next { right:8px; }
|
|
.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-excerpt { margin-bottom:16px; }
|
|
.excerpt-text { font-size:0.88rem; color:var(--text); line-height:1.65; }
|
|
|
|
.excerpt-text h2 { font-size:1.05rem; font-weight:700; color:var(--navy); margin:20px 0 8px; }
|
|
.excerpt-text h3 { font-size:0.95rem; font-weight:600; color:var(--navy); margin:16px 0 6px; }
|
|
.excerpt-text p { margin-bottom:10px; }
|
|
.excerpt-text ul { margin:8px 0 12px 20px; }
|
|
.excerpt-text li { margin-bottom:4px; font-size:0.88rem; color:var(--text); }
|
|
.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-section { transition:opacity 0.3s; }
|
|
.map-section.map-hidden #map-container { display:none; }
|
|
.map-section.map-hidden .map-empty { display:flex!important; }
|
|
.map-empty { display:none; align-items:center; justify-content:center; height:300px; border:2px dashed var(--gray-200); border-radius:var(--radius-lg); color:var(--gray-400); font-size:1rem; background:var(--white); }
|
|
#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; }
|
|
|
|
}
|