/* 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); clip-path:polygon(0 0, 100% 0, 100% calc(100% - 60px), 50% 100%, 0 calc(100% - 60px)); margin-bottom:-60px; z-index:1; } .hero-overlay { position:absolute; inset:0; background:linear-gradient(135deg,rgba(10,24,50,0.95) 0%,rgba(19,40,68,0.98) 50%,rgba(10,24,50,0.95) 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; } /* ==================== HERO SLIDER ==================== */ .hero-brand { margin-bottom:28px; } .hero-tagline { font-size:1.05rem; font-weight:300; color:rgba(255,255,255,0.6); margin-top:8px; } .hero-slider { position:relative; min-height:280px; } .hero-slide { position:absolute; top:0; left:0; width:100%; opacity:0; transform:translateY(12px); transition:opacity 0.6s ease, transform 0.6s ease; pointer-events:none; visibility:hidden; } .hero-slide.active { position:relative; opacity:1; transform:translateY(0); pointer-events:auto; visibility:visible; } .hero-slide.exiting { opacity:0; transform:translateY(-12px); transition:opacity 0.4s ease, transform 0.4s ease; } .hero-slide-inner { display:flex; gap:40px; align-items:flex-start; } .hero-slide-text-col { flex:1; min-width:0; } .hero-slide-media-col { flex:0 0 360px; display:none; } .hero-slide-media-col:has(img) { display:block; } .hero-slide-media-col img { width:100%; height:auto; border-radius:var(--radius-lg); box-shadow:0 8px 32px rgba(0,0,0,0.3); } .hero-slide-label { display:inline-block; padding:4px 14px; border-radius:20px; font-size:0.72rem; font-weight:700; letter-spacing:0.08em; text-transform:uppercase; background:var(--gold); color:var(--navy); margin-bottom:14px; } .hero-slide-headline { font-size:2rem; font-weight:700; line-height:1.15; margin-bottom:16px; color:var(--white); letter-spacing:-0.01em; } .hero-slide-text { font-size:1.05rem; font-weight:300; line-height:1.65; color:rgba(255,255,255,0.8); margin-bottom:12px; max-width:640px; } .hero-slide-example { font-size:0.88rem; font-weight:400; line-height:1.5; color:var(--gold); opacity:0.85; margin-bottom:24px; max-width:640px; padding-left:14px; border-left:2px solid rgba(200,168,81,0.4); } .hero-slide-cta { display:flex; gap:16px; flex-wrap:wrap; } .hero-slide-cta .btn-placeholder { opacity:0.5; cursor:default; border-style:dashed; pointer-events:none; } .hero-slider-nav { display:flex; align-items:center; gap:20px; margin-top:32px; } .hero-slider-dots { display:flex; gap:10px; } .hero-dot { width:10px; height:10px; border-radius:50%; border:2px solid var(--gold); background:transparent; cursor:pointer; transition:all 0.3s; padding:0; } .hero-dot.active { background:var(--gold); } .hero-slider-arrows { display:flex; gap:8px; margin-left:auto; } .hero-arrow { width:36px; height:36px; border-radius:50%; border:1px solid rgba(255,255,255,0.3); background:transparent; color:var(--white); font-size:1rem; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:all 0.2s; } .hero-arrow:hover { border-color:var(--gold); color:var(--gold); } /* ==================== HERO SLIDER ==================== */ .hero-brand { margin-bottom:28px; } .hero-tagline { font-size:1.05rem; font-weight:300; color:rgba(255,255,255,0.6); margin-top:8px; } .hero-slider { position:relative; min-height:280px; } .hero-slide { position:absolute; top:0; left:0; width:100%; opacity:0; transform:translateY(12px); transition:opacity 0.6s ease, transform 0.6s ease; pointer-events:none; visibility:hidden; } .hero-slide.active { position:relative; opacity:1; transform:translateY(0); pointer-events:auto; visibility:visible; } .hero-slide.exiting { opacity:0; transform:translateY(-12px); transition:opacity 0.4s ease, transform 0.4s ease; } .hero-slide-inner { display:flex; gap:40px; align-items:flex-start; } .hero-slide-text-col { flex:1; min-width:0; } .hero-slide-media-col { flex:0 0 360px; display:none; } .hero-slide-media-col:has(img) { display:block; } .hero-slide-media-col img { width:100%; height:auto; border-radius:var(--radius-lg); box-shadow:0 8px 32px rgba(0,0,0,0.3); } .hero-slide-label { display:inline-block; padding:4px 14px; border-radius:20px; font-size:0.72rem; font-weight:700; letter-spacing:0.08em; text-transform:uppercase; background:var(--gold); color:var(--navy); margin-bottom:14px; } .hero-slide-headline { font-size:2rem; font-weight:700; line-height:1.15; margin-bottom:16px; color:var(--white); letter-spacing:-0.01em; } .hero-slide-text { font-size:1.05rem; font-weight:300; line-height:1.65; color:rgba(255,255,255,0.8); margin-bottom:12px; max-width:640px; } .hero-slide-example { font-size:0.88rem; font-weight:400; line-height:1.5; color:var(--gold); opacity:0.85; margin-bottom:24px; max-width:640px; padding-left:14px; border-left:2px solid rgba(200,168,81,0.4); } .hero-slide-cta { display:flex; gap:16px; flex-wrap:wrap; } .hero-slide-cta .btn-placeholder { opacity:0.5; cursor:default; border-style:dashed; pointer-events:none; } .hero-slider-nav { display:flex; align-items:center; gap:20px; margin-top:32px; } .hero-slider-dots { display:flex; gap:10px; } .hero-dot { width:10px; height:10px; border-radius:50%; border:2px solid var(--gold); background:transparent; cursor:pointer; transition:all 0.3s; padding:0; } .hero-dot.active { background:var(--gold); } .hero-slider-arrows { display:flex; gap:8px; margin-left:auto; } .hero-arrow { width:36px; height:36px; border-radius:50%; border:1px solid rgba(255,255,255,0.3); background:transparent; color:var(--white); font-size:1rem; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:all 0.2s; } .hero-arrow:hover { border-color:var(--gold); color:var(--gold); } /* ==================== 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-light { color:rgba(255,255,255,0.6); } .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-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; } #features .grid-3 { justify-items:center; } #features .grid-3 .feature-card:nth-last-child(-n+2):nth-child(3n+1) { grid-column: 1; } #features .grid-3 { display:flex; flex-wrap:wrap; justify-content:center; } #features .grid-3 .feature-card { width:calc(33.333% - 20px); } .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; } /* ==================== CONTACT MODAL ==================== */ .modal-overlay { position:fixed; inset:0; z-index:9999; background:rgba(10,24,50,0.6); backdrop-filter:blur(4px); display:flex; align-items:center; justify-content:center; padding:24px; } .modal-content { background:var(--white); border-radius:var(--radius-lg); padding:40px; max-width:520px; width:100%; position:relative; box-shadow:0 24px 64px rgba(10,24,50,0.3); max-height:90vh; overflow-y:auto; } .modal-close { position:absolute; top:16px; right:20px; background:none; border:none; font-size:1.8rem; color:var(--gray-400); cursor:pointer; line-height:1; } .modal-close:hover { color:var(--navy); } .modal-content h2 { font-size:1.5rem; font-weight:700; color:var(--navy); margin-bottom:8px; } .modal-sub { font-size:0.95rem; color:var(--text-light); margin-bottom:28px; } .form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; } .form-group { margin-bottom:16px; } .form-group label { display:block; font-size:0.82rem; font-weight:600; color:var(--navy); margin-bottom:6px; text-transform:uppercase; letter-spacing:0.04em; } .form-group input, .form-group textarea { width:100%; padding:10px 14px; border:1px solid var(--gray-200); border-radius:var(--radius); font-family:inherit; font-size:0.95rem; color:var(--text); background:var(--base); transition:border-color 0.2s; } .form-group input:focus, .form-group textarea:focus { outline:none; border-color:var(--gold); } .form-group textarea { resize:vertical; } .form-success { text-align:center; padding:40px 0; } .form-success p { font-size:1.05rem; color:var(--navy); font-weight:500; } @media(max-width:768px) { .form-row { grid-template-columns:1fr; } .modal-content { padding:28px 20px; } } /* ==================== 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; } .hero-slide-media-col { flex:0 0 280px; } } @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%; } .hero-slider { min-height:320px; } .hero-slide-headline { font-size:1.5rem; } .hero-slide-text { font-size:0.95rem; } .hero-slide-inner { flex-direction:column; gap:20px; } .hero-slide-media-col { flex:none; width:100%; } .hero-slider-arrows { display:none; } .hero-slide-cta { flex-direction:column; } .hero-slide-cta .btn { width:100%; } .footer-content { flex-direction:column; text-align:center; gap:16px; } #map-container { height:300px; } #features .grid-3 { display:flex; flex-direction:column; } #features .grid-3 .feature-card { width:100%; } .carousel-card { width:100%!important; max-width:100%; position:relative!important; } .carousel-card.active { transform:none; } .carousel-card.left, .carousel-card.right { display:none; } .carousel-track { display:flex; flex-direction:column; } .carousel-arrow { display:none; } .carousel-viewport { overflow:visible; } .live-stats-bar { padding:0 8px; } .live-stats-row { gap:12px; } .live-stat { min-width:0; padding:16px 12px; } .live-stat-value { font-size:1.8rem; } } @media(max-width:480px) { .hero-title { font-size:1.8rem; } .container { padding:0 16px; } }