@font-face {
font-family: 'Montserrat';
src: url(//taniepv.pl/wp-content/themes/bywitek-theme/assets/fonts/Montserrat-Light.woff2) format('woff2');
font-weight: 300;
font-style: normal;
font-display: swap;
}
@font-face {
font-family: 'Noto Sans Display';
src: url(//taniepv.pl/wp-content/themes/bywitek-theme/assets/fonts/NotoSansDisplay-Light.ttf) format('truetype');
font-weight: 300;
font-style: normal;
font-display: swap;
}
@font-face {
font-family: 'Noto Sans Display';
src: url(//taniepv.pl/wp-content/themes/bywitek-theme/assets/fonts/NotoSansDisplay-Regular.ttf) format('truetype');
font-weight: 400;
font-style: normal;
font-display: swap;
}
@font-face {
font-family: 'Noto Sans Display';
src: url(//taniepv.pl/wp-content/themes/bywitek-theme/assets/fonts/NotoSansDisplay-Medium.ttf) format('truetype');
font-weight: 500;
font-style: normal;
font-display: swap;
}
@font-face {
font-family: 'Noto Sans Display';
src: url(//taniepv.pl/wp-content/themes/bywitek-theme/assets/fonts/NotoSansDisplay-SemiBold.ttf) format('truetype');
font-weight: 600;
font-style: normal;
font-display: swap;
}
@font-face {
font-family: 'Noto Sans Display';
src: url(//taniepv.pl/wp-content/themes/bywitek-theme/assets/fonts/NotoSansDisplay-ExtraBold.ttf) format('truetype');
font-weight: 800;
font-style: normal;
font-display: swap;
}
:root {
--primary: #0073aa;
}
* {
margin: 0;
padding: 0;
box-sizing: border-box;
}.site-header-wrapper {
position: sticky;
top: 0;
z-index: 1001;
width: 100%;
background: transparent;
padding-top: 30px;
transition: padding-top 220ms ease;
}
.site-header-wrapper.is-scrolled {
padding-top: 12px;
}
.site-header-content {
width: 100%;
max-width: none;
padding: 0 8rem;
display: flex;
align-items: center;
gap: 0.75rem;
}
.site-logo {
width: 82px;
height: 82px;
min-width: 82px;
border-radius: 6px;
display: flex;
align-items: center;
justify-content: center;
background: #fff;
color: #fff;
text-decoration: none;
overflow: hidden;
border: 1px solid #d0d5dd;
box-shadow: 0 6px 16px rgba(16, 24, 40, 0.06);
cursor: pointer;
transition: filter 180ms ease;
}
.site-logo:hover,
.site-logo:focus-visible {
filter: brightness(0.96);
}
.site-logo img {
width: 100%;
height: 100%;
object-fit: contain;
}
.site-logo-text {
font-family: 'Noto Sans Display', sans-serif;
font-size: 1rem;
font-weight: 700;
line-height: 1;
text-transform: lowercase;
}
.site-header-main {
flex: 1;
min-height: 82px;
background: #fff;
border: 1px solid #d0d5dd;
border-radius: 6px;
box-shadow: 0 6px 16px rgba(16, 24, 40, 0.06);
display: flex;
align-items: center;
justify-content: flex-end;
padding: 0 0.75rem;
}
.site-nav-desktop {
width: 100%;
display: flex;
align-items: center;
justify-content: space-between;
gap: 0.8rem;
}
.site-nav-desktop a {
color: #111;
text-decoration: none;
font-family: 'Noto Sans Display', sans-serif;
font-size: 1rem;
font-weight: 600;
line-height: 1;
white-space: nowrap;
transition: color 180ms ease, background-color 180ms ease;
}
.site-nav-desktop .site-nav-cta {
background: var(--primary);
color: #fff;
border-radius: 4px;
min-height: 0;
margin: 0.75rem 0 0.75rem 0.5rem;
padding: 1rem 1.8rem;
display: inline-flex;
align-items: center;
justify-content: center;
transition: filter 180ms ease;
}
.site-nav-desktop a:hover,
.site-nav-desktop a:focus-visible {
color: var(--primary);
}
.site-nav-desktop .site-nav-cta:hover,
.site-nav-desktop .site-nav-cta:focus-visible {
color: #fff;
filter: brightness(0.92);
}
.site-nav-toggle-box {
display: none;
}
.site-nav-toggle {
display: inline-flex;
border: 0;
outline: 0;
background: transparent;
width: 100%;
height: 100%;
border-radius: 6px;
cursor: pointer;
padding: 0;
align-items: center;
justify-content: center;
position: relative;
overflow: hidden;
}
.site-nav-toggle-icon {
width: 32px;
height: 32px;
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
transition: opacity 220ms ease, transform 260ms ease;
}
.site-nav-toggle-icon-open {
opacity: 1;
transform: translate(-50%, -50%) rotate(0deg) translateX(0);
}
.site-nav-toggle-icon-close {
opacity: 0;
transform: translate(-50%, -50%) rotate(-90deg) translateX(10px);
}
.site-header-wrapper.is-drawer-open .site-nav-toggle-icon-close {
opacity: 1;
transform: translate(-50%, -50%) rotate(0deg) translateX(0);
}
.site-header-wrapper.is-drawer-open .site-nav-toggle-icon-open {
opacity: 0;
transform: translate(-50%, -50%) rotate(90deg) translateX(-10px);
}
.site-mobile-drawer {
display: none;
}
@media (max-width: 1439px) {
.site-header-content {
padding: 0 4rem;
}
.site-nav-desktop a {
font-size: 0.9rem;
}
.site-nav-desktop .site-nav-cta {
min-height: 0;
margin: 0.75rem 0 0.75rem 0.5rem;
padding: 0.85rem 1.3rem;
}
}
@media (max-width: 1199px) {
.site-header-content {
padding: 0 2rem;
}
.site-logo,
.site-header-main {
min-height: 74px;
height: 74px;
}
.site-logo {
width: 74px;
min-width: 74px;
}
.site-nav-desktop .site-nav-cta {
min-height: 0;
margin: 0.75rem 0 0.75rem 0.45rem;
padding: 0.7rem 1rem;
}
.site-nav-desktop {
gap: 0.55rem;
}
.site-nav-desktop a {
font-size: 0.8rem;
}
}
@media (max-width: 991px) {
.site-header-content {
padding: 0 1rem;
justify-content: space-between;
}
.site-logo,
.site-header-main,
.site-nav-toggle-box {
min-height: 62px;
height: 62px;
}
.site-logo {
width: 62px;
min-width: 62px;
}
.site-nav-toggle-box {
width: 62px;
min-width: 62px;
display: flex;
align-items: center;
justify-content: center;
background: #fff;
border: 1px solid #d0d5dd;
box-shadow: 0 6px 16px rgba(16, 24, 40, 0.06);
border-radius: 6px;
position: relative;
z-index: 1003;
}
.site-header-main {
display: none;
}
.site-nav-desktop {
display: none;
}
.site-nav-toggle {
display: inline-flex;
}
.site-nav-toggle-icon {
width: 34px;
height: 34px;
}
.site-mobile-drawer {
position: fixed;
inset: 0;
z-index: 1000;
background: #fff;
transform: translateX(100%);
opacity: 0;
pointer-events: none;
transition: transform 220ms ease, opacity 220ms ease;
padding: 6.8rem 1rem 1rem;
display: flex;
flex-direction: column;
align-items: flex-start;
gap: 1rem;
}
.site-mobile-drawer a {
color: #111;
text-decoration: none;
font-family: 'Noto Sans Display', sans-serif;
font-size: 1.35rem;
font-weight: 700;
line-height: 1.2;
transition: color 180ms ease, background-color 180ms ease;
}
.site-mobile-drawer a:hover,
.site-mobile-drawer a:focus-visible {
color: var(--primary);
}
.site-mobile-drawer .site-mobile-cta {
margin-top: 0.65rem;
background: var(--primary);
color: #fff;
border-radius: 6px;
padding: 0.95rem 1.15rem;
transition: filter 180ms ease;
}
.site-mobile-drawer .site-mobile-cta:hover,
.site-mobile-drawer .site-mobile-cta:focus-visible {
color: #fff;
filter: brightness(0.92);
}
.site-header-wrapper.is-drawer-open .site-mobile-drawer {
transform: translateX(0);
opacity: 1;
pointer-events: auto;
}
}.site-footer {
width: 100vw;
margin-left: calc(50% - 50vw);
background: linear-gradient(180deg, #001a74 0%, #00145f 100%);
color: #ffffff;
padding: 4rem 0 2rem;
}
.site-footer-content {
width: 100%;
max-width: 100%;
padding: 0 5rem;
margin: 0 auto;
}
.site-footer-top {
display: grid;
grid-template-columns: minmax(260px, 1.3fr) minmax(220px, 1fr) minmax(200px, 0.9fr) minmax(200px, 0.9fr);
gap: 2.5rem;
padding-bottom: 3rem;
border-bottom: 1px solid rgba(255, 255, 255, 0.12);
}
.site-footer-brand-title {
margin: 0;
font-family: 'Noto Sans Display', sans-serif;
font-size: clamp(2rem, 2.4vw, 3.1rem);
line-height: 1.1;
font-weight: 800;
}
.site-footer-brand-link {
text-decoration: none;
color: inherit;
display: inline-flex;
flex-direction: column;
cursor: pointer;
}
.site-footer-brand-link:hover .site-footer-brand-title,
.site-footer-brand-link:focus-visible .site-footer-brand-title {
color: #33d2ff;
}
.site-footer-brand-subtitle {
margin: 1.6rem 0 0;
max-width: 28rem;
font-family: 'Noto Sans Display', sans-serif;
font-size: clamp(1rem, 1.15vw, 1.55rem);
line-height: 1.35;
font-weight: 500;
color: rgba(255, 255, 255, 0.75);
}
.site-footer-heading {
margin: 0 0 1.4rem;
font-family: 'Noto Sans Display', sans-serif;
font-size: clamp(1.4rem, 1.8vw, 2.3rem);
line-height: 1.1;
font-weight: 800;
}
.site-footer-contact-link {
display: inline-flex;
align-items: center;
gap: 0.9rem;
text-decoration: none;
color: rgba(255, 255, 255, 0.86);
font-family: 'Noto Sans Display', sans-serif;
font-size: clamp(1.1rem, 1.2vw, 1.75rem);
line-height: 1.3;
font-weight: 500;
margin-bottom: 1.2rem;
}
.site-footer-contact-icon-wrap {
width: 2rem;
min-width: 2rem;
height: 2rem;
display: inline-flex;
align-items: center;
justify-content: center;
}
.site-footer-contact-icon-wrap img {
width: 100%;
height: 100%;
display: block;
filter: brightness(0) saturate(100%) invert(76%) sepia(78%) saturate(1974%) hue-rotate(152deg) brightness(98%) contrast(96%);
}
.site-footer-links,
.site-footer-documents,
.site-footer-contact {
display: flex;
flex-direction: column;
}
.site-footer-links a,
.site-footer-documents a {
text-decoration: none;
color: rgba(255, 255, 255, 0.76);
font-family: 'Noto Sans Display', sans-serif;
font-size: clamp(1.1rem, 1.2vw, 1.72rem);
line-height: 1.4;
font-weight: 500;
margin-bottom: 1rem;
}
.site-footer-bottom {
margin-top: 2.1rem;
display: flex;
align-items: center;
justify-content: space-between;
gap: 1rem;
}
.site-footer-copy,
.site-footer-credit {
margin: 0;
font-family: 'Noto Sans Display', sans-serif;
font-size: clamp(1rem, 1.05vw, 1.35rem);
line-height: 1.3;
font-weight: 500;
color: rgba(255, 255, 255, 0.55);
}
.site-footer a {
transition: color 180ms ease;
}
.site-footer a:hover,
.site-footer a:focus-visible {
color: #33d2ff;
}
.site-footer-credit a {
color: rgba(255, 255, 255, 0.9);
text-decoration: none;
}
@media (max-width: 1200px) {
.site-footer-content {
padding: 0 2rem;
}
.site-footer-top {
grid-template-columns: 1fr 1fr;
}
}
@media (max-width: 768px) {
.site-footer {
padding: 2.8rem 0 1.5rem;
}
.site-footer-content {
padding: 0 1rem;
}
.site-footer-top {
grid-template-columns: 1fr;
gap: 1.4rem;
padding-bottom: 1.6rem;
}
.site-footer-brand-title {
font-size: 2rem;
}
.site-footer-brand-subtitle {
margin-top: 0.9rem;
font-size: 1.15rem;
}
.site-footer-heading {
margin-bottom: 0.7rem;
font-size: 1.7rem;
}
.site-footer-contact-link,
.site-footer-links a,
.site-footer-documents a {
font-size: 1.25rem;
margin-bottom: 0.65rem;
}
.site-footer-bottom {
margin-top: 1.4rem;
flex-direction: column;
align-items: flex-start;
gap: 0.45rem;
}
.site-footer-copy,
.site-footer-credit {
font-size: 1rem;
}
}.home .site-main {
width: 100%;
}
.home .site-content {
margin-top: -112px;
}
.home-hero {
width: 100vw;
margin-left: calc(50% - 50vw);
position: relative;
min-height: 60vh;
height: 60vh;
padding-top: 112px;
overflow: hidden;
display: flex;
align-items: center;
justify-content: center;
}
.home-hero-slides {
position: absolute;
inset: 0;
}
.home-hero-slide {
position: absolute;
inset: 0;
background-size: cover;
background-position: center;
opacity: 0;
transition: opacity 950ms ease;
transform: scale(1.02);
}
.home-hero-slide.is-empty {
background: linear-gradient(120deg, #2a2f3a 0%, #1b2432 60%, #121a2c 100%);
}
.home-hero-slide::after {
content: '';
position: absolute;
inset: 0;
background: rgba(0, 0, 0, 0.48);
}
.home-hero-slide.is-active {
opacity: 1;
}
.home-hero-content {
position: relative;
z-index: 2;
width: min(100%, 900px);
padding: 0 1rem;
text-align: center;
color: #fff;
display: flex;
flex-direction: column;
align-items: center;
gap: 1.45rem;
}
.home-hero-content h1 {
font-family: 'Noto Sans Display', sans-serif;
font-size: clamp(2rem, 3.6vw, 3.2rem);
font-weight: 800;
line-height: 1.1;
}
.home-hero-content p {
font-family: 'Montserrat', sans-serif;
font-size: clamp(0.95rem, 1.2vw, 1.55rem);
font-weight: 300;
line-height: 1.45;
max-width: 860px;
}
.home-hero-actions {
display: flex;
align-items: center;
justify-content: center;
gap: 1.4rem;
margin-top: 0.5rem;
}
.home-hero-button {
background: var(--primary);
color: #fff;
border-radius: 4px;
padding: 0.85rem 1.4rem;
text-decoration: none;
display: inline-flex;
align-items: center;
justify-content: center;
font-family: 'Noto Sans Display', sans-serif;
font-size: 1rem;
font-weight: 600;
line-height: 1;
text-transform: uppercase;
letter-spacing: 0.01em;
transition: filter 180ms ease;
}
.home-hero-button:hover,
.home-hero-button:focus-visible {
filter: brightness(0.92);
}
.home-hero-timer {
position: absolute;
z-index: 3;
left: 0;
right: 0;
bottom: 0;
height: 2px;
background: rgba(130, 130, 130, 0.25);
backdrop-filter: blur(2px);
}
.home-hero-timer-bar {
display: block;
width: 0;
height: 100%;
background: rgba(255, 255, 255, 0.55);
filter: blur(0.5px);
}
@media (max-width: 991px) {
.home .site-content {
margin-top: -92px;
}
.home-hero {
padding-top: 92px;
min-height: 68vh;
height: 68vh;
}
.home-hero-content {
gap: 1.1rem;
}
.home-hero-content p {
line-height: 1.4;
}
.home-hero-actions {
gap: 0.75rem;
}
.home-hero-button {
font-size: 1.15rem;
padding: 0.85rem 1rem;
}
}
@media (max-width: 640px) {
.home-hero {
min-height: 72vh;
height: 72vh;
}
.home-hero-content h1 {
font-size: clamp(1.75rem, 9.2vw, 2.2rem);
}
.home-hero-content p {
font-size: 1rem;
}
.home-hero-actions {
flex-direction: row;
flex-wrap: wrap;
}
}
.business-section {
width: 100vw;
margin-left: calc(50% - 50vw);
padding: 5rem 0;
}
.business-section-content {
width: 100%;
max-width: 100%;
padding: 0 9rem;
margin: 0 auto;
}
.business-section-heading {
font-family: 'Noto Sans Display', sans-serif;
font-size: clamp(2rem, 3.6vw, 3.2rem);
font-weight: 800;
line-height: 1.1;
text-align: center;
margin-bottom: 3rem;
color: #1a1a1a;
}
.business-services-grid {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 1.5rem;
width: 100%;
}
.business-services-small {
display: grid;
grid-template-rows: 1fr 1fr;
gap: 1.5rem;
}
.business-service {
position: relative;
overflow: hidden;
border-radius: 8px;
min-height: 300px;
display: flex;
flex-direction: column;
cursor: pointer;
}
.business-service-large {
min-height: 618px;
}
.business-service-small {
min-height: 300px;
}
.business-service-bg {
position: absolute;
inset: 0;
overflow: hidden;
}
.business-service-bg-image {
width: 100%;
height: 100%;
object-fit: cover;
object-position: center;
}
.business-service-bg:empty {
background: linear-gradient(120deg, #2a2f3a 0%, #1b2432 60%, #121a2c 100%);
}
.business-service-bg::after {
content: '';
position: absolute;
inset: 0;
background: rgba(0, 0, 0, 0.62);
z-index: 1;
}
.business-service-content {
position: relative;
z-index: 2;
display: flex;
flex-direction: column;
justify-content: space-between;
height: 100%;
padding: 2rem;
color: #fff;
}
.business-service-header {
display: flex;
flex-direction: column;
gap: 1rem;
}
.business-service-title {
font-family: 'Noto Sans Display', sans-serif;
font-size: clamp(1.4rem, 2vw, 1.8rem);
font-weight: 600;
line-height: 1.2;
margin: 0;
}
.business-service-description {
max-height: 0;
overflow: hidden;
opacity: 0;
transition: max-height 450ms ease, opacity 350ms ease;
}
.business-service-description p {
font-family: 'Montserrat', sans-serif;
font-size: clamp(0.9rem, 1.1vw, 1rem);
font-weight: 300;
line-height: 1.5;
margin: 0;
}
.business-service:hover .business-service-description {
max-height: 300px;
opacity: 1;
}
.business-service-footer {
display: flex;
align-items: flex-end;
margin-top: auto;
}
.business-service-button {
background: var(--primary);
color: #fff;
border-radius: 4px;
padding: 0.75rem 1.2rem;
text-decoration: none;
display: inline-flex;
align-items: center;
justify-content: center;
font-family: 'Noto Sans Display', sans-serif;
font-size: 0.95rem;
font-weight: 600;
line-height: 1;
text-transform: uppercase;
letter-spacing: 0.01em;
transition: filter 180ms ease;
}
.business-service-button:hover,
.business-service-button:focus-visible {
filter: brightness(0.92);
}
@media (max-width: 991px) {
.business-section-content {
padding: 0 3rem;
}
.business-section-heading {
margin-bottom: 2.5rem;
}
.business-services-grid {
gap: 1.2rem;
}
.business-services-small {
gap: 1.2rem;
}
.business-service-large {
min-height: 500px;
}
.business-service-small {
min-height: 240px;
}
}
@media (max-width: 768px) {
.business-section {
padding: 3rem 0;
}
.business-section-content {
padding: 0 1rem;
}
.business-section-heading {
font-size: clamp(1.75rem, 9.2vw, 2.2rem);
margin-bottom: 2rem;
}
.business-services-grid {
grid-template-columns: 1fr;
gap: 1rem;
}
.business-services-small {
grid-template-rows: auto;
gap: 1rem;
}
.business-service-large {
min-height: 350px;
}
.business-service-small {
min-height: 300px;
}
.business-service-content {
padding: 1.5rem;
}
.business-service-title {
font-size: 1.3rem;
}
.business-service.is-active .business-service-description {
max-height: 300px;
opacity: 1;
}
.business-service:hover .business-service-description {
max-height: 0;
opacity: 0;
}
.business-service.is-active:hover .business-service-description {
max-height: 300px;
opacity: 1;
}
.business-service-button {
font-size: 0.9rem;
padding: 0.65rem 1rem;
}
}
.why-choose-us-section {
width: 100vw;
margin-left: calc(50% - 50vw);
background: #fff;
padding: 5rem 0;
}
.why-choose-us-content {
width: 100%;
max-width: 100%;
padding: 0 9rem;
margin: 0 auto;
display: grid;
grid-template-columns: 1fr 1fr;
gap: 4rem;
align-items: center;
}
.why-choose-us-text {
display: flex;
flex-direction: column;
gap: 1.5rem;
}
.why-choose-us-subtitle {
font-family: 'Noto Sans Display', sans-serif;
font-size: 0.875rem;
font-weight: 600;
letter-spacing: 0.1em;
text-transform: uppercase;
color: var(--primary);
}
.why-choose-us-heading {
font-family: 'Noto Sans Display', sans-serif;
font-size: clamp(2rem, 3.6vw, 3.2rem);
font-weight: 800;
line-height: 1.1;
color: #1a1a1a;
}
.why-choose-us-description {
font-family: 'Noto Sans Display', sans-serif;
font-size: 1.125rem;
line-height: 1.6;
color: #4a4a4a;
}
.why-choose-us-benefits {
list-style: none;
padding: 0;
margin: 0;
display: flex;
flex-direction: column;
gap: 1rem;
}
.why-benefit {
display: flex;
align-items: center;
gap: 0.75rem;
font-family: 'Noto Sans Display', sans-serif;
font-size: 1rem;
font-weight: 500;
color: #1a1a1a;
}
.why-benefit-icon {
flex-shrink: 0;
width: 24px;
height: 24px;
color: var(--primary);
}
.why-choose-us-image-wrapper {
position: relative;
width: 100%;
height: 100%;
min-height: 400px;
}
.why-choose-us-image {
width: 100%;
height: 100%;
object-fit: cover;
border-radius: 8px;
}
.why-choose-us-image-placeholder {
width: 100%;
height: 100%;
min-height: 400px;
background: linear-gradient(120deg, #2a2f3a 0%, #1b2432 60%, #121a2c 100%);
border-radius: 8px;
}
@media (max-width: 991px) {
.why-choose-us-content {
padding: 0 1rem;
grid-template-columns: 1fr;
gap: 2.5rem;
}
.why-choose-us-heading {
font-size: clamp(1.75rem, 9.2vw, 2.2rem);
}
.why-choose-us-description {
font-size: 1rem;
}
.why-choose-us-image-wrapper {
min-height: 300px;
}
.why-choose-us-image-placeholder {
min-height: 300px;
}
}
@media (max-width: 640px) {
.why-choose-us-section {
padding: 3rem 0;
}
.why-choose-us-content {
gap: 1rem;
}
.why-choose-us-subtitle {
font-size: 0.75rem;
}
.why-benefit {
font-size: 0.9375rem;
}
.why-benefit-icon {
width: 20px;
height: 20px;
}
}
.how-it-works-section {
width: 100vw;
margin-left: calc(50% - 50vw);
background: linear-gradient(135deg, #000e53 0%, #001a80 100%);
padding: 5rem 0;
}
.how-it-works-content {
width: 100%;
max-width: 100%;
padding: 0 2rem;
margin: 0 auto;
}
.how-it-works-heading {
font-family: 'Noto Sans Display', sans-serif;
font-size: clamp(2rem, 3.6vw, 3.2rem);
font-weight: 800;
line-height: 1.1;
text-align: center;
margin-bottom: 3.5rem;
color: #fff;
}
.how-it-works-slider-wrapper {
position: relative;
}
.how-it-works-steps {
display: grid;
grid-template-columns: repeat(4, 1fr);
gap: 2rem;
margin-bottom: 3rem;
}
.how-it-works-steps::-webkit-scrollbar {
display: none;
}
.how-step {
scroll-snap-align: center;
backdrop-filter: blur(10px);
background: rgba(255, 255, 255, 0.05);
padding: 40px;
border-radius: 16px;
border: 1px solid rgba(255, 255, 255, 0.1);
display: flex;
flex-direction: column;
gap: 1rem;
box-sizing: border-box;
}
.how-step-number {
font-family: 'Noto Sans Display', sans-serif;
font-size: 3rem;
font-weight: 800;
color: rgb(76, 201, 240);
line-height: 1;
}
.how-step-title {
font-family: 'Noto Sans Display', sans-serif;
font-size: 1.4rem;
font-weight: 600;
color: #fff;
line-height: 1.3;
margin: 0;
}
.how-step-description {
font-family: 'Montserrat', sans-serif;
font-size: 0.95rem;
font-weight: 300;
color: rgba(255, 255, 255, 0.85);
line-height: 1.6;
margin: 0;
}
.how-it-works-cta {
backdrop-filter: blur(10px);
background: rgba(255, 255, 255, 0.05);
padding: 40px;
border-radius: 16px;
border: 1px solid rgba(255, 255, 255, 0.1);
display: flex;
align-items: center;
justify-content: space-between;
gap: 2rem;
margin-bottom: 3rem;
}
.how-cta-text {
font-family: 'Noto Sans Display', sans-serif;
font-size: clamp(1.4rem, 2.5vw, 2rem);
font-weight: 600;
color: #fff;
line-height: 1.2;
}
.how-cta-highlight {
color: rgb(76, 201, 240);
}
.how-cta-button {
background: var(--primary);
color: #fff;
border-radius: 4px;
padding: 1rem 2rem;
text-decoration: none;
display: inline-flex;
align-items: center;
justify-content: center;
font-family: 'Noto Sans Display', sans-serif;
font-size: 1rem;
font-weight: 600;
line-height: 1;
text-transform: uppercase;
letter-spacing: 0.01em;
transition: filter 180ms ease;
white-space: nowrap;
}
.how-cta-button:hover,
.how-cta-button:focus-visible {
filter: brightness(0.92);
}
.slider-indicators {
display: none;
gap: 0.5rem;
justify-content: center;
align-items: center;
padding: 1rem 0 1.5rem 0;
}
@media (max-width: 768px) {
.slider-indicators {
display: flex;
}
}
.slider-indicator {
width: 10px;
height: 10px;
border-radius: 50%;
background: rgba(255, 255, 255, 0.3);
border: none;
padding: 0;
cursor: pointer;
transition: all 0.3s ease;
}
.slider-indicator:hover {
background: rgba(255, 255, 255, 0.5);
}
.slider-indicator.is-active {
background: rgb(76, 201, 240);
width: 24px;
border-radius: 5px;
}
@media (max-width: 991px) {
.how-it-works-content {
padding: 0 1.5rem;
}
.how-it-works-heading {
margin-bottom: 3rem;
}
.how-it-works-steps {
grid-template-columns: repeat(2, 1fr);
gap: 1.5rem;
}
.how-step {
padding: 30px;
}
.how-it-works-cta {
padding: 30px;
}
}
@media (max-width: 768px) {
.how-it-works-section .slider-indicators {
padding: 1.25rem 0;
}
.how-it-works-section {
padding: 3rem 0;
}
.how-it-works-content {
padding: 0 1rem;
}
.how-it-works-heading {
font-size: clamp(1.75rem, 9.2vw, 2.2rem);
margin-bottom: 2rem;
}
.how-it-works-steps {
display: flex;
gap: 0;
overflow-x: auto;
scroll-snap-type: x mandatory;
scroll-behavior: smooth;
-webkit-overflow-scrolling: touch;
scrollbar-width: none;
margin-bottom: 0;
padding: 0;
cursor: grab;
grid-template-columns: none;
}
.how-it-works-steps:active {
cursor: grabbing;
}
.how-step {
flex: 0 0 100%;
scroll-snap-align: start;
scroll-snap-stop: always;
margin: 0;
padding: 25px 1rem;
box-sizing: border-box;
}
.how-step:not(:last-child) {
margin-right: 1rem;
}
.how-step.clone {
margin-right: 1rem;
}
.how-step.clone:last-child {
margin-right: 0;
}
.how-step-number {
font-size: 2.5rem;
}
.how-step-title {
font-size: 1.25rem;
}
.how-step-description {
font-size: 0.9rem;
}
.how-it-works-cta {
padding: 25px;
flex-direction: column;
align-items: center;
text-align: center;
gap: 1.5rem;
}
.how-cta-text {
font-size: 1.3rem;
}
.how-cta-button {
width: 100%;
padding: 0.9rem 1.5rem;
}
}
.business-benefits-section {
width: 100vw;
margin-left: calc(50% - 50vw);
background: linear-gradient(135deg, #000e53 0%, #001a80 100%);
padding: 5rem 0;
}
.business-benefits-content {
width: 100%;
max-width: 100%;
padding: 0 2rem;
margin: 0 auto;
}
.business-benefits-heading {
font-family: 'Noto Sans Display', sans-serif;
font-size: clamp(2rem, 3.6vw, 3.2rem);
font-weight: 800;
line-height: 1.1;
text-align: center;
margin-bottom: 3.5rem;
color: #fff;
}
.business-benefits-slider-wrapper {
position: relative;
}
.business-benefits-grid {
display: grid;
grid-template-columns: repeat(5, 1fr);
gap: 2rem;
}
.business-benefits-grid::-webkit-scrollbar {
display: none;
}
.business-benefit {
scroll-snap-align: center;
backdrop-filter: blur(10px);
background: rgba(255, 255, 255, 0.05);
padding: 40px;
border-radius: 16px;
border: 1px solid rgba(255, 255, 255, 0.1);
display: flex;
flex-direction: column;
align-items: center;
gap: 1.5rem;
text-align: center;
box-sizing: border-box;
}
.business-benefit-icon-wrapper {
width: 100px;
height: 100px;
border-radius: 50%;
background: rgba(76, 201, 240, 0.15);
display: flex;
align-items: center;
justify-content: center;
flex-shrink: 0;
}
.business-benefit-icon {
font-size: 3rem;
color: rgb(76, 201, 240);
}
.business-benefit-title {
font-family: 'Noto Sans Display', sans-serif;
font-size: 1.1rem;
font-weight: 600;
color: #fff;
line-height: 1.3;
margin: 0;
}
@media (max-width: 991px) {
.business-benefits-content {
padding: 0 1.5rem;
}
.business-benefits-heading {
font-size: clamp(1.8rem, 4vw, 2.4rem);
margin-bottom: 2.5rem;
}
.business-benefits-grid {
grid-template-columns: repeat(2, 1fr);
gap: 1.5rem;
}
.business-benefit {
padding: 30px;
}
.business-benefit-icon-wrapper {
width: 90px;
height: 90px;
}
.business-benefit-icon {
font-size: 2.5rem;
}
.business-benefit-title {
font-size: 1rem;
}
}
@media (max-width: 768px) {
.business-benefits-section {
padding: 3rem 0;
}
.business-benefits-content {
padding: 0 1rem;
}
.business-benefits-heading {
font-size: 1.6rem;
margin-bottom: 2rem;
}
.business-benefits-grid {
display: flex;
gap: 0;
overflow-x: auto;
scroll-snap-type: x mandatory;
scroll-behavior: smooth;
-webkit-overflow-scrolling: touch;
scrollbar-width: none;
margin-bottom: 0;
padding: 0;
cursor: grab;
grid-template-columns: none;
}
.business-benefits-grid:active {
cursor: grabbing;
}
.business-benefit {
flex: 0 0 100%;
scroll-snap-align: start;
scroll-snap-stop: always;
margin: 0;
padding: 25px 1rem;
gap: 1rem;
box-sizing: border-box;
}
.business-benefit:not(:last-child) {
margin-right: 1rem;
}
.business-benefit.clone {
margin-right: 1rem;
}
.business-benefit.clone:last-child {
margin-right: 0;
}
.business-benefit-icon-wrapper {
width: 80px;
height: 80px;
}
.business-benefit-icon {
font-size: 2.2rem;
}
.business-benefit-title {
font-size: 0.95rem;
}
}
.business-unified-bg {
width: 100%;
}
.contact-section {
width: 100vw;
margin-left: calc(50% - 50vw);
background: #fff;
padding: 4rem 0;
}
.contact-content {
width: 100%;
max-width: 1400px;
margin: 0 auto;
padding: 0 2rem;
display: grid;
grid-template-columns: minmax(280px, 430px) minmax(0, 1fr);
gap: 2rem;
}
.contact-info-card,
.contact-form-card {
background: linear-gradient(135deg, #000e53 0%, #001a80 100%);
border-radius: 18px;
padding: 2.75rem;
}
.contact-info-card {
display: flex;
flex-direction: column;
gap: 1.5rem;
}
.contact-info-heading {
font-family: 'Noto Sans Display', sans-serif;
font-size: clamp(2rem, 4vw, 3.5rem);
font-weight: 800;
color: #fff;
line-height: 1.1;
margin: 0;
}
.contact-info-description {
font-family: 'Noto Sans Display', sans-serif;
font-size: clamp(1.2rem, 1.5vw, 1.65rem);
font-weight: 500;
color: rgba(255, 255, 255, 0.75);
line-height: 1.35;
margin: 0;
}
.contact-links {
display: grid;
gap: 1rem;
margin-top: 1rem;
}
.contact-link-item {
display: flex;
align-items: center;
gap: 1.2rem;
background: rgba(255, 255, 255, 0.08);
border: 1px solid rgba(255, 255, 255, 0.08);
border-radius: 14px;
padding: 1rem;
text-decoration: none;
font-family: 'Noto Sans Display', sans-serif;
font-size: clamp(1rem, 1.1vw, 1.6rem);
font-weight: 700;
color: #fff;
transition: background 180ms ease, border-color 180ms ease;
}
.contact-link-item:hover,
.contact-link-item:focus-visible {
background: rgba(255, 255, 255, 0.12);
border-color: rgba(255, 255, 255, 0.2);
}
.contact-link-icon-wrap {
width: 58px;
height: 58px;
border-radius: 50%;
background: rgba(76, 201, 240, 0.15);
display: inline-flex;
align-items: center;
justify-content: center;
flex-shrink: 0;
}
.contact-link-icon-wrap img {
width: 24px;
height: 24px;
filter: brightness(0) saturate(100%) invert(76%) sepia(78%) saturate(1974%) hue-rotate(152deg) brightness(98%) contrast(96%);
}
.contact-form {
display: flex;
flex-direction: column;
gap: 1.3rem;
}
.contact-form-honeypot {
position: absolute;
left: -9999px;
width: 1px;
height: 1px;
overflow: hidden;
}
.contact-form-grid {
display: grid;
grid-template-columns: repeat(2, minmax(0, 1fr));
gap: 1.15rem 1.35rem;
}
.contact-form-field {
display: flex;
flex-direction: column;
gap: 0.45rem;
}
.contact-form-field label {
font-family: 'Noto Sans Display', sans-serif;
font-size: 0.8rem;
line-height: 1;
letter-spacing: 0.03em;
font-weight: 700;
color: #fff;
}
.contact-form-field input,
.contact-form-field textarea {
width: 100%;
border: 1px solid rgba(255, 255, 255, 0.12);
background: rgba(255, 255, 255, 0.08);
border-radius: 6px;
color: #fff;
font-family: 'Noto Sans Display', sans-serif;
font-size: 1rem;
font-weight: 600;
line-height: 1.2;
outline: none;
transition: border-color 180ms ease, background 180ms ease;
}
.contact-form-field input {
min-height: 56px;
padding: 0.85rem 1rem;
}
.contact-form-field textarea {
min-height: 124px;
padding: 0.9rem 1rem;
resize: none;
}
.contact-form-field input::placeholder,
.contact-form-field textarea::placeholder {
color: rgba(255, 255, 255, 0.48);
}
.contact-form-field input:focus,
.contact-form-field textarea:focus {
border-color: rgba(76, 201, 240, 0.8);
background: rgba(255, 255, 255, 0.12);
}
.contact-form-field.has-error input,
.contact-form-field.has-error textarea {
border-color: #ff6e6e;
}
.contact-form-error {
margin: 0;
font-family: 'Noto Sans Display', sans-serif;
font-size: 0.82rem;
line-height: 1.3;
font-weight: 500;
color: #ff6e6e;
max-height: 0;
opacity: 0;
transform: translateY(-8px);
overflow: hidden;
transition: max-height 220ms ease, opacity 220ms ease, transform 220ms ease;
}
.contact-form-field.has-error .contact-form-error {
max-height: 42px;
opacity: 1;
transform: translateY(0);
}
.contact-form-field-full {
width: 100%;
}
.contact-form-submit {
width: auto;
min-height: 0;
border: 0;
border-radius: 4px;
background: var(--primary);
color: #fff;
font-family: 'Noto Sans Display', sans-serif;
font-size: 1rem;
font-weight: 600;
line-height: 1;
text-transform: uppercase;
letter-spacing: 0.01em;
padding: 0.85rem 1.4rem;
display: inline-flex;
align-items: center;
justify-content: center;
align-self: flex-start;
cursor: pointer;
transition: filter 180ms ease;
}
.contact-form-submit:hover,
.contact-form-submit:focus-visible {
filter: brightness(0.92);
}
.contact-form-submit:disabled {
opacity: 0.75;
cursor: not-allowed;
}
.contact-form-status {
display: none;
margin: 0;
font-family: 'Noto Sans Display', sans-serif;
font-size: 0.9rem;
line-height: 1.35;
font-weight: 500;
opacity: 0;
transform: translateY(-8px);
}
.contact-form-status.is-visible {
display: block;
opacity: 1;
transform: translateY(0);
animation: contactStatusSlideIn 250ms ease;
}
.contact-form-status.is-error {
color: #ff6e6e;
}
.contact-form-status.is-success {
color: #82f2ad;
}
@keyframes contactStatusSlideIn {
from {
opacity: 0;
transform: translateY(-8px);
}
to {
opacity: 1;
transform: translateY(0);
}
}
.contact-form-privacy {
margin: 0.2rem 0 0;
font-family: 'Noto Sans Display', sans-serif;
font-size: 0.9rem;
font-weight: 400;
line-height: 1.45;
color: rgba(255, 255, 255, 0.72);
}
.contact-form-privacy a {
color: #fff;
text-decoration: underline;
text-underline-offset: 2px;
}
.contact-form-privacy a:hover,
.contact-form-privacy a:focus-visible {
color: rgb(76, 201, 240);
}
@media (max-width: 1100px) {
.contact-content {
grid-template-columns: 1fr;
}
.contact-info-card,
.contact-form-card {
padding: 2rem;
}
}
@media (max-width: 768px) {
.business-unified-bg {
width: 100vw;
margin-left: calc(50% - 50vw);
background: linear-gradient(135deg, #000e53 0%, #001a80 100%);
}
.business-benefits-section,
.contact-section {
width: 100%;
margin-left: 0;
background: transparent;
}
.business-benefits-section {
padding-bottom: 1.5rem;
}
.contact-section {
padding: 30px 0 3rem;
}
.contact-content {
padding: 0 1rem;
gap: 1.25rem;
}
.contact-info-card,
.contact-form-card {
padding: 1.4rem;
border-radius: 14px;
background: rgba(255, 255, 255, 0.05);
border: 1px solid rgba(255, 255, 255, 0.08);
}
.contact-info-heading {
font-size: 2.1rem;
}
.contact-info-description {
font-size: 1.15rem;
}
.contact-link-item {
font-size: 1.3rem;
padding: 0.9rem;
border-radius: 12px;
}
.contact-link-icon-wrap {
width: 50px;
height: 50px;
border-radius: 50%;
}
.contact-form-grid {
grid-template-columns: 1fr;
gap: 1rem;
}
.contact-form-submit {
min-height: 0;
font-size: 1rem;
padding: 0.85rem 1.4rem;
}
.contact-form-privacy {
font-size: 0.86rem;
}
}
.faq-section {
width: 100vw;
margin-left: calc(50% - 50vw);
background: #fff;
padding: 4.5rem 0 5rem;
}
.faq-content {
width: 100%;
max-width: 100%;
padding: 0 9rem;
margin: 0 auto;
}
.faq-heading {
margin: 0 0 2rem;
text-align: center;
font-family: 'Noto Sans Display', sans-serif;
font-size: clamp(2rem, 3.3vw, 3.4rem);
line-height: 1.1;
font-weight: 800;
color: #2f3137;
}
.featured-realizations-slider-wrapper {
position: relative;
}
.faq-list {
display: flex;
flex-direction: column;
gap: 1rem;
}
.faq-item {
background: #fff;
border: 1px solid #d7dde4;
border-radius: 12px;
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.04);
overflow: hidden;
}
.faq-question {
width: 100%;
border: 0;
background: transparent;
text-align: left;
padding: 1.35rem 1.5rem;
display: flex;
align-items: center;
justify-content: space-between;
gap: 1.25rem;
cursor: pointer;
}
.faq-question-text {
font-family: 'Noto Sans Display', sans-serif;
font-size: clamp(1.1rem, 1.5vw, 1.9rem);
line-height: 1.28;
font-weight: 700;
color: #323338;
transition: color 160ms ease;
}
.faq-toggle-wrap {
display: inline-flex;
align-items: center;
gap: 0.75rem;
flex-shrink: 0;
}
.faq-toggle-label {
font-family: 'Noto Sans Display', sans-serif;
font-size: clamp(0.9rem, 1vw, 1.25rem);
line-height: 1;
font-weight: 600;
color: #4f5560;
transition: color 160ms ease;
}
.faq-toggle-icon {
display: inline-flex;
align-items: center;
justify-content: center;
width: 1.2rem;
font-family: 'Noto Sans Display', sans-serif;
font-size: 1.8rem;
line-height: 1;
font-weight: 700;
color: #0977b9;
transform: rotate(0deg);
transform-origin: center;
transition: transform 280ms cubic-bezier(0.2, 0.7, 0.2, 1);
}
.faq-item:hover .faq-question-text,
.faq-item:hover .faq-toggle-label,
.faq-item.is-open .faq-question-text,
.faq-item.is-open .faq-toggle-label {
color: var(--primary);
}
.faq-item.is-open .faq-toggle-icon {
transform: rotate(45deg);
}
.faq-answer {
max-height: 0;
opacity: 0;
transform: translateY(-12px);
overflow: hidden;
padding: 0 1.5rem;
transition: max-height 360ms cubic-bezier(0.2, 0.7, 0.2, 1), opacity 280ms ease, transform 320ms ease, padding-top 320ms ease, padding-bottom 320ms ease;
}
.faq-item.is-open .faq-answer {
max-height: 380px;
opacity: 1;
transform: translateY(0);
padding-bottom: 1.25rem;
}
.faq-answer p {
margin: 0;
font-family: 'Noto Sans Display', sans-serif;
font-size: clamp(1rem, 1.15vw, 1.45rem);
line-height: 1.45;
font-weight: 600;
color: #5d646f;
}
@media (max-width: 991px) {
.faq-content {
padding: 0 3rem;
}
}
@media (max-width: 768px) {
.faq-section {
padding: 3.2rem 0 3.5rem;
}
.faq-content {
padding: 0 1rem;
}
.faq-heading {
margin-bottom: 1.5rem;
font-size: 2rem;
}
.faq-question {
padding: 1rem;
align-items: flex-start;
}
.faq-question-text {
font-size: 1.25rem;
}
.faq-toggle-wrap {
margin-top: 0.1rem;
}
.faq-toggle-label {
font-size: 0.95rem;
}
.faq-toggle-icon {
font-size: 1.55rem;
}
.faq-answer {
padding: 0 1rem;
}
.faq-item.is-open .faq-answer {
max-height: 430px;
padding-bottom: 1rem;
}
.faq-answer p {
font-size: 1.05rem;
}
}
.featured-realizations-section {
width: 100vw;
margin-left: calc(50% - 50vw);
background: #fff;
padding: 4.5rem 0;
}
.featured-realizations-content {
width: 100%;
max-width: 100%;
padding: 0 9rem;
margin: 0 auto;
}
.featured-realizations-heading {
margin: 0 0 2rem;
text-align: center;
font-family: 'Noto Sans Display', sans-serif;
font-size: clamp(2rem, 3.3vw, 3.4rem);
line-height: 1.1;
font-weight: 800;
color: #2f3137;
}
.featured-realizations-grid {
display: grid;
grid-template-columns: repeat(2, minmax(0, 1fr));
gap: 1.5rem;
}
.featured-realization-tile {
position: relative;
min-height: 400px;
border-radius: 16px;
overflow: hidden;
background: #d6dbe2;
}
.featured-realization-image-wrap {
position: absolute;
inset: 0;
}
.featured-realization-image,
.featured-realization-image-placeholder {
width: 100%;
height: 100%;
object-fit: cover;
}
.featured-realization-image-placeholder {
background: linear-gradient(160deg, #2e3340 0%, #48536d 100%);
}
.featured-realization-overlay {
position: absolute;
inset: 0;
padding: 1.5rem;
display: flex;
flex-direction: column;
justify-content: flex-start;
background: linear-gradient(180deg, rgba(7, 15, 34, 0.66) 0%, rgba(7, 15, 34, 0.28) 45%, rgba(7, 15, 34, 0.6) 100%);
}
.featured-realization-title {
margin: 0;
max-width: 82%;
font-family: 'Noto Sans Display', sans-serif;
font-size: clamp(1.2rem, 1.5vw, 1.95rem);
line-height: 1.2;
font-weight: 800;
color: #ffffff;
}
.featured-realization-description {
margin: 0.7rem 0 0;
max-width: 85%;
font-family: 'Noto Sans Display', sans-serif;
font-size: clamp(0.98rem, 1.05vw, 1.28rem);
line-height: 1.4;
font-weight: 600;
color: rgba(255, 255, 255, 0.92);
}
.featured-realizations-section .slider-indicator {
background: rgba(47, 49, 55, 0.28);
}
.featured-realizations-section .slider-indicator:hover {
background: rgba(47, 49, 55, 0.45);
}
.featured-realizations-section .slider-indicator.is-active {
background: rgb(76, 201, 240);
}
@media (max-width: 1200px) {
.featured-realizations-content {
padding: 0 2rem;
}
}
@media (max-width: 768px) {
.featured-realizations-section {
padding: 3.2rem 0;
}
.featured-realizations-content {
padding: 0 1rem;
}
.featured-realizations-heading {
margin-bottom: 1.35rem;
font-size: 2rem;
}
.featured-realizations-grid {
display: flex;
gap: 0;
overflow-x: auto;
scroll-snap-type: x mandatory;
scroll-behavior: smooth;
-webkit-overflow-scrolling: touch;
scrollbar-width: none;
margin-bottom: 0;
padding: 0;
cursor: grab;
grid-template-columns: none;
}
.featured-realizations-grid:active {
cursor: grabbing;
}
.featured-realization-tile {
flex: 0 0 100%;
scroll-snap-align: start;
scroll-snap-stop: always;
margin: 0;
min-height: 320px;
box-sizing: border-box;
}
.featured-realization-tile:not(:last-child) {
margin-right: 1rem;
}
.featured-realization-tile.clone {
margin-right: 1rem;
}
.featured-realization-tile.clone:last-child {
margin-right: 0;
}
.featured-realization-overlay {
padding: 1rem;
}
.featured-realization-title {
max-width: 100%;
font-size: 1.3rem;
}
.featured-realization-description {
max-width: 100%;
font-size: 1rem;
}
}