.wpcf7 .screen-reader-response {
position: absolute;
overflow: hidden;
clip: rect(1px, 1px, 1px, 1px);
clip-path: inset(50%);
height: 1px;
width: 1px;
margin: -1px;
padding: 0;
border: 0;
word-wrap: normal !important;
word-break: normal !important;
}
.wpcf7 .hidden-fields-container {
display: none;
}
.wpcf7 form .wpcf7-response-output {
margin: 2em 0.5em 1em;
padding: 0.2em 1em;
border: 2px solid #00a0d2; }
.wpcf7 form.init .wpcf7-response-output,
.wpcf7 form.resetting .wpcf7-response-output,
.wpcf7 form.submitting .wpcf7-response-output {
display: none;
}
.wpcf7 form.sent .wpcf7-response-output {
border-color: #46b450; }
.wpcf7 form.failed .wpcf7-response-output,
.wpcf7 form.aborted .wpcf7-response-output {
border-color: #dc3232; }
.wpcf7 form.spam .wpcf7-response-output {
border-color: #f56e28; }
.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output,
.wpcf7 form.payment-required .wpcf7-response-output {
border-color: #ffb900; }
.wpcf7-form-control-wrap {
position: relative;
}
.wpcf7-not-valid-tip {
color: #dc3232; font-size: 1em;
font-weight: normal;
display: block;
}
.use-floating-validation-tip .wpcf7-not-valid-tip {
position: relative;
top: -2ex;
left: 1em;
z-index: 100;
border: 1px solid #dc3232;
background: #fff;
padding: .2em .8em;
width: 24em;
}
.wpcf7-list-item {
display: inline-block;
margin: 0 0 0 1em;
}
.wpcf7-list-item-label::before,
.wpcf7-list-item-label::after {
content: " ";
}
.wpcf7-spinner {
visibility: hidden;
display: inline-block;
background-color: #23282d; opacity: 0.75;
width: 24px;
height: 24px;
border: none;
border-radius: 100%;
padding: 0;
margin: 0 24px;
position: relative;
}
form.submitting .wpcf7-spinner {
visibility: visible;
}
.wpcf7-spinner::before {
content: '';
position: absolute;
background-color: #fbfbfc; top: 4px;
left: 4px;
width: 6px;
height: 6px;
border: none;
border-radius: 100%;
transform-origin: 8px 8px;
animation-name: spin;
animation-duration: 1000ms;
animation-timing-function: linear;
animation-iteration-count: infinite;
}
@media (prefers-reduced-motion: reduce) {
.wpcf7-spinner::before {
animation-name: blink;
animation-duration: 2000ms;
}
}
@keyframes spin {
from {
transform: rotate(0deg);
}
to {
transform: rotate(360deg);
}
}
@keyframes blink {
from {
opacity: 0;
}
50% {
opacity: 1;
}
to {
opacity: 0;
}
}
.wpcf7 [inert] {
opacity: 0.5;
}
.wpcf7 input[type="file"] {
cursor: pointer;
}
.wpcf7 input[type="file"]:disabled {
cursor: default;
}
.wpcf7 .wpcf7-submit:disabled {
cursor: not-allowed;
}
.wpcf7 input[type="url"],
.wpcf7 input[type="email"],
.wpcf7 input[type="tel"] {
direction: ltr;
}
.wpcf7-reflection > output {
display: list-item;
list-style: none;
}
.wpcf7-reflection > output[hidden] {
display: none;
}article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
nav,
section,
summary {
display: block;
} audio,
canvas,
video {
display: inline-block;
} audio:not([controls]) {
display: none;
height: 0;
} [hidden],
template {
display: none;
}  html {
font-family: sans-serif; -ms-text-size-adjust: 100%; -webkit-text-size-adjust: 100%; } body {
margin: 0;
}  a {
background: transparent;
} a:focus {
outline: thin dotted;
} a:active,
a:hover {
outline: 0;
}  h1 {
font-size: 2em;
margin: 0.67em 0;
} abbr[title] {
border-bottom: 1px dotted;
} b,
strong {
font-weight: bold;
} dfn {
font-style: italic;
} hr {
-moz-box-sizing: content-box;
box-sizing: content-box;
height: 0;
} mark {
background: #ff0;
color: #000;
} code,
kbd,
pre,
samp {
font-family: monospace, serif;
font-size: 1em;
} pre {
white-space: pre-wrap;
} q {
quotes: "\201C" "\201D" "\2018" "\2019";
} small {
font-size: 80%;
} sub,
sup {
font-size: 75%;
line-height: 0;
position: relative;
vertical-align: baseline;
}
sup {
top: -0.5em;
}
sub {
bottom: -0.25em;
}  img {
border: 0;
} svg:not(:root) {
overflow: hidden;
}  figure {
margin: 0;
}  fieldset {
border: 1px solid #c0c0c0;
margin: 0 2px;
padding: 0.35em 0.625em 0.75em;
} legend {
border: 0; padding: 0; } button,
input,
select,
textarea {
font-family: inherit; font-size: 100%; margin: 0; } button,
input {
line-height: normal;
} button,
select {
text-transform: none;
} button,
html input[type="button"], input[type="reset"],
input[type="submit"] {
-webkit-appearance: button; cursor: pointer; } button[disabled],
html input[disabled] {
cursor: default;
} input[type="checkbox"],
input[type="radio"] {
box-sizing: border-box; padding: 0; } input[type="search"] {
-webkit-appearance: textfield; -moz-box-sizing: content-box;
-webkit-box-sizing: content-box; box-sizing: content-box;
} input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration {
-webkit-appearance: none;
} button::-moz-focus-inner,
input::-moz-focus-inner {
border: 0;
padding: 0;
} textarea {
overflow: auto; vertical-align: top; }  table {
border-collapse: collapse;
border-spacing: 0;
}.slick-slider
{
position: relative;
display: block;
box-sizing: border-box;
-webkit-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
user-select: none;
-webkit-touch-callout: none;
-khtml-user-select: none;
-ms-touch-action: pan-y;
touch-action: pan-y;
-webkit-tap-highlight-color: transparent;
}
.slick-list
{
position: relative;
display: block;
overflow: hidden;
margin: 0;
padding: 0;
}
.slick-list:focus
{
outline: none;
}
.slick-list.dragging
{
cursor: pointer;
cursor: hand;
}
.slick-slider .slick-track,
.slick-slider .slick-list
{
-webkit-transform: translate3d(0, 0, 0);
-moz-transform: translate3d(0, 0, 0);
-ms-transform: translate3d(0, 0, 0);
-o-transform: translate3d(0, 0, 0);
transform: translate3d(0, 0, 0);
}
.slick-track
{
position: relative;
top: 0;
left: 0;
display: block;
margin-left: auto;
margin-right: auto;
}
.slick-track:before,
.slick-track:after
{
display: table;
content: '';
}
.slick-track:after
{
clear: both;
}
.slick-loading .slick-track
{
visibility: hidden;
}
.slick-slide
{
display: none;
float: left;
height: 100%;
min-height: 1px;
}
[dir='rtl'] .slick-slide
{
float: right;
}
.slick-slide img
{
display: block;
}
.slick-slide.slick-loading img
{
display: none;
}
.slick-slide.dragging img
{
pointer-events: none;
}
.slick-initialized .slick-slide
{
display: block;
}
.slick-loading .slick-slide
{
visibility: hidden;
}
.slick-vertical .slick-slide
{
display: block;
height: auto;
border: 1px solid transparent;
}
.slick-arrow.slick-hidden {
display: none;
}:root {
--bg-primary: #0a0e1a;
--bg-secondary: #111827;
--bg-card: rgba(17, 24, 39, 0.35);
--bg-card-strong: rgba(17, 24, 39, 0.5);
--text-primary: #f8fafc;
--text-secondary: #94a3b8;
--accent: #0ea5e9;
--accent-soft: rgba(14, 165, 233, 0.1);
--border: rgba(148, 163, 184, 0.18);
--border-soft: rgba(148, 163, 184, 0.1);
--shadow-accent: 0 18px 35px rgba(14, 165, 233, 0.22);
--radius: 8px;
--transition: 0.28s ease;
}
* {
box-sizing: border-box;
}
html {
scroll-behavior: smooth;
}
body {
margin: 0;
font-family: "Inter", sans-serif;
background: var(--bg-primary);
color: var(--text-primary);
line-height: 1.45;
}
img,
svg {
display: block;
max-width: 100%;
}
a {
color: inherit;
text-decoration: none;
}
button,
input,
textarea {
font: inherit;
}
section[id] {
scroll-margin-top: 92px;
}
.grecaptcha-badge {
top: -999999px;
}
.container {
width: min(1280px, calc(100% - 96px));
margin: 0 auto;
}
.section {
padding: 128px 0;
position: relative;
}
.section--gradient-a {
background:
radial-gradient(circle at 50% 50%, rgba(14, 165, 233, 0.07) 0%, rgba(17, 24, 39, 0) 60%),
linear-gradient(180deg, var(--bg-primary) 0%, rgba(17, 24, 39, 0.3) 100%);
}
.section--gradient-b {
background:
radial-gradient(circle at 50% 50%, rgba(14, 165, 233, 0.08) 0%, rgba(17, 24, 39, 0) 62%),
linear-gradient(180deg, rgba(17, 24, 39, 0.3) 0%, var(--bg-primary) 100%);
}
.section--process {
background:
linear-gradient(180deg, transparent 0%, transparent 100%),
radial-gradient(circle at 50% 35%, rgba(14, 165, 233, 0.07) 0%, transparent 52%),
var(--bg-primary);
}
.section__container {
display: flex;
flex-direction: column;
gap: 64px;
}
.section__container--compact {
gap: 56px;
}
.section__head {
text-align: center;
}
.section-tag {
margin: 0 0 16px;
color: var(--accent);
font-size: 14px;
text-transform: uppercase;
letter-spacing: 0.55px;
}
.section-tag--pill {
display: inline-flex;
margin-bottom: 26px;
padding: 8px 16px;
border-radius: 999px;
background: rgba(14, 165, 233, 0.1);
border: 1px solid rgba(14, 165, 233, 0.2);
text-transform: none;
letter-spacing: 0.2px;
width: fit-content;
}
.section-title {
margin: 0;
font-size: clamp(2rem, 3.3vw, 3rem);
line-height: 1.06;
font-weight: 700;
letter-spacing: 0.2px;
}
.site-header {
position: fixed;
top: 0;
left: 0;
width: 100%;
z-index: 1000;
background: rgba(10, 14, 26, 0.82);
border-bottom: 1px solid var(--border);
backdrop-filter: blur(8px);
}
.site-header.is-scrolled {
background: rgba(10, 14, 26, 0.94);
}
.header__container {
height: 72px;
display: flex;
align-items: center;
justify-content: space-between;
}
.brand {
display: inline-flex;
align-items: center;
}
.brand__logo {
width: 106px;
height: 52px;
object-fit: cover;
}
.nav {
display: flex;
align-items: center;
gap: 32px;
}
.nav__link {
font-size: 14px;
font-weight: 600;
color: var(--text-secondary);
transition: color var(--transition);
}
.nav__link:hover,
.nav__link:focus-visible {
color: var(--text-primary);
}
.menu-toggle {
display: none;
border: 0;
background: transparent;
cursor: pointer;
width: 44px;
height: 44px;
padding: 0;
align-items: center;
justify-content: center;
flex-direction: column;
gap: 5px;
}
.menu-toggle span {
width: 20px;
height: 2px;
background: var(--text-primary);
border-radius: 2px;
transition: transform var(--transition), opacity var(--transition);
}
.menu-toggle.is-active span:nth-child(1) {
transform: translateY(7px) rotate(45deg);
}
.menu-toggle.is-active span:nth-child(2) {
opacity: 0;
}
.menu-toggle.is-active span:nth-child(3) {
transform: translateY(-7px) rotate(-45deg);
}
.btn {
display: inline-flex;
align-items: center;
justify-content: center;
gap: 10px;
padding: 16px 32px;
border-radius: var(--radius);
border: 0;
background: var(--accent);
color: #fff;
font-size: 16px;
font-weight: 600;
line-height: 1;
cursor: pointer;
transition: transform var(--transition), box-shadow var(--transition), background var(--transition);
}
.btn:hover,
.btn:focus-visible {
transform: translateY(-2px);
box-shadow: var(--shadow-accent);
}
.btn--sm {
height: 40px;
padding: 0 24px;
font-size: 16px;
}
.btn--lg {
height: 60px;
padding: 0 32px;
font-size: 18px;
width: fit-content;
}
.btn--full {
width: 100%;
height: 56px;
}
.hero {
position: relative;
min-height: 962px;
padding-top: 72px;
overflow: hidden;
}
.hero__bg,
.hero__overlay {
position: absolute;
inset: 0;
}
.hero__bg {
background-image: url(https://proavx.com/wp-content/uploads/2026/04/Image-Professional-AV-Studio.jpg);
background-position: center;
background-size: cover;
}
.hero__overlay {
background: linear-gradient(90deg,
rgba(10, 14, 26, 1) 0%,
rgba(10, 14, 26, 0.95) 48%,
rgba(10, 14, 26, 0.6) 100%);
}
.hero__container {
position: relative;
z-index: 1;
display: flex;
flex-direction: column;
justify-content: center;
min-height: calc(962px - 72px);
}
.hero__title {
margin: 0;
font-size: clamp(3rem, 5.1vw, 4.5rem);
line-height: 1.1;
font-weight: 700;
letter-spacing: -1px;
max-width: 768px;
}
.hero__subtitle {
margin: 24px 0 40px;
color: var(--text-secondary);
font-size: 20px;
line-height: 1.55;
}
.scroll-indicator {
position: absolute;
left: 50%;
bottom: 32px;
transform: translateX(-50%);
width: 24px;
height: 40px;
border: 2px solid rgba(14, 165, 233, 0.5);
border-radius: 999px;
display: flex;
justify-content: center;
padding-top: 8px;
z-index: 2;
}
.scroll-indicator span {
width: 4px;
height: 8px;
border-radius: 999px;
background: var(--accent);
animation: scroll-dot 1.3s infinite;
}
@keyframes scroll-dot {
0% {
opacity: 0.3;
transform: translateY(0);
}
50% {
opacity: 1;
transform: translateY(8px);
}
100% {
opacity: 0.3;
transform: translateY(0);
}
}
.about__content {
display: grid;
grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
gap: 64px;
align-items: center;
}
.about__text {
color: var(--text-secondary);
font-size: 18px;
line-height: 1.63;
display: grid;
gap: 24px;
}
.about__text p {
margin: 0;
}
.about__image-wrap {
margin: 0;
border-radius: var(--radius);
overflow: hidden;
box-shadow: 0 25px 50px rgba(0, 0, 0, 0.25);
}
.about__image {
width: 100%;
height: 100%;
min-height: 370px;
object-fit: cover;
}
.about__cards {
display: grid;
grid-template-columns: repeat(3, minmax(0, 1fr));
gap: 24px;
}
.feature-card,
.service-card,
.testimonial-card,
.process-step {
border: 1px solid var(--border-soft);
border-radius: var(--radius);
}
.feature-card {
background: var(--bg-card-strong);
padding: 32px;
}
.feature-card--center {
text-align: center;
display: flex;
flex-direction: column;
align-items: center;
}
.feature-card h3 {
margin: 16px 0 8px;
font-size: 20px;
line-height: 1.3;
}
.feature-card p {
margin: 0;
color: var(--text-secondary);
font-size: 16px;
line-height: 1.5;
}
.services-grid {
display: grid;
grid-template-columns: repeat(4, minmax(0, 1fr));
gap: 24px;
}
.service-card {
background: var(--bg-card);
padding: 32px;
min-height: 290px;
display: flex;
flex-direction: column;
}
.service-card h3 {
margin: 24px 0 12px;
font-size: 20px;
line-height: 1.12;
}
.service-card p {
margin: 0;
color: var(--text-secondary);
font-size: 16px;
line-height: 1.6;
}
.gallery-grid {
display: grid;
grid-template-columns: repeat(3, minmax(0, 1fr));
gap: 24px;
}
.gallery-item {
margin: 0;
border: 0;
padding: 0;
border-radius: var(--radius);
overflow: hidden;
cursor: pointer;
background: transparent;
aspect-ratio: 378.6 / 284;
transition: transform var(--transition), box-shadow var(--transition);
}
.gallery-item:hover,
.gallery-item:focus-visible {
transform: translateY(-3px);
box-shadow: 0 18px 32px rgba(0, 0, 0, 0.28);
}
.gallery-item img {
width: 100%;
height: 100%;
object-fit: cover;
}
.portfolio-grid {
display: grid;
grid-template-columns: repeat(3, minmax(0, 1fr));
gap: 24px;
}
.portfolio-card {
overflow: hidden;
border-radius: var(--radius);
border: 1px solid var(--border-soft);
background: var(--bg-card);
}
.portfolio-card img {
width: 100%;
height: 280px;
object-fit: cover;
}
.portfolio-card__body {
padding: 24px;
}
.portfolio-card h3 {
margin: 0 0 8px;
font-size: 20px;
line-height: 1.16;
}
.portfolio-card p {
margin: 0;
color: var(--text-secondary);
font-size: 14px;
line-height: 1.6;
}
.differentials-grid {
display: grid;
grid-template-columns: repeat(2, minmax(0, 1fr));
gap: 48px 48px;
}
.differential-item {
display: flex;
gap: 16px;
align-items: flex-start;
}
.differential-item h3 {
margin: 0 0 10px;
font-size: 24px;
line-height: 1.2;
}
.differential-item p {
margin: 0;
color: var(--text-secondary);
font-size: 16px;
line-height: 1.6;
}
.process-grid {
display: grid;
grid-template-columns: repeat(4, minmax(0, 1fr));
gap: 24px;
}
.process-step {
background: transparent;
padding: 0 8px;
border: 0;
text-align: center;
}
.process-step__head {
display: inline-flex;
align-items: center;
margin-bottom: 24px;
position: relative;
}
.step-index {
position: relative;
z-index: 1;
width: 64px;
height: 64px;
border-radius: 50%;
background: var(--accent);
color: #fff;
display: flex;
align-items: center;
justify-content: center;
font-size: 24px;
font-weight: 500;
}
.process-step__head .icon-badge {
margin-left: -10px;
width: 80px;
height: 80px;
background: var(--bg-secondary);
border: 1px solid var(--border);
border-radius: var(--radius);
}
.process-step h3 {
margin: 0 0 12px;
font-size: 24px;
line-height: 1.06;
}
.process-step p {
margin: 0;
color: var(--text-secondary);
font-size: 16px;
line-height: 1.6;
}
.testimonials-grid {
display: grid;
grid-template-columns: repeat(3, minmax(0, 1fr));
gap: 24px;
}
.testimonial-card {
background: var(--bg-card);
padding: 32px;
}
.testimonial-card__icon {
margin: 0 0 20px;
color: var(--accent);
font-size: 32px;
line-height: 1;
}
.testimonial-card blockquote {
margin: 0;
color: var(--text-secondary);
font-size: 16px;
line-height: 1.6;
font-style: italic;
min-height: 142px;
}
.testimonial-card__name {
margin: 24px 0 2px;
padding-top: 22px;
border-top: 1px solid var(--border-soft);
font-size: 16px;
}
.testimonial-card__role {
margin: 0;
color: var(--text-secondary);
font-size: 14px;
}
.testimonial-card__company {
margin: 0;
color: var(--accent);
font-size: 14px;
}
.final-cta {
position: relative;
padding: 128px 0;
background: linear-gradient(180deg, rgba(17, 24, 39, 0.3) 0%, var(--bg-primary) 100%);
overflow: hidden;
}
.final-cta__radial {
position: absolute;
inset: 0;
opacity: 0.25;
background: radial-gradient(circle at 50% 50%, rgba(14, 165, 233, 0.55) 0%, rgba(0, 0, 0, 0) 64%);
pointer-events: none;
}
.final-cta__content {
position: relative;
z-index: 1;
text-align: center;
max-width: 928px;
}
.final-cta h2 {
margin: 0;
font-size: clamp(2.4rem, 5.1vw, 3.75rem);
line-height: 1.15;
letter-spacing: 0.25px;
}
.final-cta p {
margin: 24px auto 40px;
max-width: 672px;
color: var(--text-secondary);
font-size: 20px;
line-height: 1.4;
}
.contact-layout {
display: grid;
grid-template-columns: repeat(2, minmax(0, 1fr));
gap: 64px;
}
.contact-title {
margin: 0 0 16px;
font-size: 24px;
line-height: 1.3;
}
.contact-text {
margin: 0;
color: var(--text-secondary);
font-size: 16px;
line-height: 1.6;
max-width: 560px;
}
.contact-list {
list-style: none;
margin: 40px 0 0;
padding: 0;
display: grid;
gap: 24px;
}
.contact-list li {
display: flex;
gap: 16px;
align-items: center;
}
.contact-list__label {
margin: 0 0 5px;
color: var(--text-secondary);
font-size: 14px;
line-height: 1.4;
}
.contact-list__value {
margin: 0;
font-size: 16px;
line-height: 1.24;
}
.wpcf7-form {
display: grid;
gap: 24px;
}
.field p {
display: grid;
gap: 8px;
margin: 0;
}
.field label {
color: var(--text-secondary);
font-size: 14px;
font-weight: 600;
}
.field input,
.field textarea {
width: 100%;
border: 1px solid var(--border);
border-radius: var(--radius);
background: var(--bg-secondary);
color: var(--text-primary);
padding: 14px 16px;
font-size: 16px;
line-height: 1.5;
transition: border-color var(--transition), box-shadow var(--transition);
}
.field textarea {
resize: vertical;
min-height: 146px;
}
.field input::placeholder,
.field textarea::placeholder {
color: rgba(148, 163, 184, 0.6);
}
.field input:focus,
.field textarea:focus {
outline: none;
border-color: rgba(14, 165, 233, 0.8);
box-shadow: 0 0 0 2px rgba(14, 165, 233, 0.2);
}
.field input[aria-invalid="true"],
.field textarea[aria-invalid="true"] {
border-color: #f87171;
}
.field__error {
min-height: 16px;
color: #fca5a5;
font-size: 13px;
line-height: 1.2;
}
.form-status {
margin: 0;
min-height: 20px;
color: #86efac;
font-size: 14px;
}
.site-footer {
background: var(--bg-secondary);
border-top: 1px solid var(--border);
}
.footer__content {
padding: 64px 0 48px;
}
.footer-grid {
display: grid;
grid-template-columns: repeat(4, minmax(0, 1fr));
gap: 48px;
}
.footer-brand {
margin: 0 0 16px;
font-size: 24px;
font-weight: 400;
}
.footer-brand span {
color: var(--accent);
}
.footer-muted {
margin: 0;
color: var(--text-secondary);
font-size: 14px;
line-height: 1.65;
max-width: 260px;
}
.site-footer h4 {
margin: 0 0 16px;
font-size: 16px;
font-weight: 600;
}
.site-footer ul {
list-style: none;
margin: 0;
padding: 0;
display: grid;
gap: 12px;
}
.site-footer li,
.site-footer a {
color: var(--text-secondary);
font-size: 14px;
line-height: 1.45;
}
.site-footer a:hover,
.site-footer a:focus-visible {
color: var(--text-primary);
}
.social-links {
margin-top: 20px;
display: flex;
gap: 16px;
}
.social-links a {
width: 40px;
height: 40px;
border-radius: var(--radius);
background: var(--accent-soft);
color: var(--accent);
display: inline-flex;
align-items: center;
justify-content: center;
font-weight: 700;
transition: transform var(--transition), background var(--transition), color var(--transition);
}
.social-links a:hover,
.social-links a:focus-visible {
transform: translateY(-2px);
background: var(--accent);
color: #fff;
}
.footer-copy {
margin: 48px 0 0;
padding-top: 33px;
border-top: 1px solid var(--border);
text-align: center;
color: var(--text-secondary);
font-size: 14px;
}
.icon-badge {
width: 56px;
height: 56px;
border-radius: var(--radius);
background: var(--accent-soft);
color: var(--accent);
display: inline-flex;
align-items: center;
justify-content: center;
flex-shrink: 0;
}
.icon-badge svg {
width: 28px;
height: 28px;
}
.icon-badge--round {
width: 64px;
height: 64px;
border-radius: 999px;
}
.icon-badge--small {
width: 48px;
height: 48px;
}
.icon-badge--small svg {
width: 22px;
height: 22px;
}
.lightbox {
position: fixed;
inset: 0;
display: flex;
align-items: center;
justify-content: center;
padding: 40px;
background: rgba(3, 6, 12, 0.94);
opacity: 0;
visibility: hidden;
pointer-events: none;
z-index: 1300;
transition: opacity var(--transition), visibility var(--transition);
}
.lightbox.is-open {
opacity: 1;
visibility: visible;
pointer-events: auto;
}
.lightbox__stage {
width: min(1120px, 100%);
text-align: center;
}
.lightbox__stage img {
width: auto;
max-width: 100%;
max-height: 75vh;
margin: 0 auto;
border-radius: var(--radius);
object-fit: contain;
opacity: 0;
transform: translateX(22px);
transition: opacity 0.22s ease, transform 0.22s ease;
}
.lightbox__stage img.is-visible {
opacity: 1;
transform: translateX(0);
}
.lightbox__caption {
margin: 16px 0 0;
color: #dbe4ef;
font-size: 16px;
}
.lightbox__counter {
margin: 8px 0 0;
color: var(--text-secondary);
font-size: 14px;
}
.lightbox__close,
.lightbox__arrow {
position: absolute;
border: 0;
border-radius: var(--radius);
background: rgba(15, 23, 42, 0.75);
color: #fff;
display: inline-flex;
align-items: center;
justify-content: center;
cursor: pointer;
transition: background var(--transition), transform var(--transition);
}
.lightbox__close:hover,
.lightbox__close:focus-visible,
.lightbox__arrow:hover,
.lightbox__arrow:focus-visible {
background: rgba(14, 165, 233, 0.9);
transform: translateY(-2px);
}
.lightbox__close {
top: 24px;
right: 24px;
width: 46px;
height: 46px;
font-size: 34px;
line-height: 1;
}
.lightbox__arrow {
top: 50%;
transform: translateY(-50%);
width: 48px;
height: 64px;
font-size: 46px;
}
.lightbox__arrow--prev {
left: 24px;
}
.lightbox__arrow--next {
right: 24px;
}
@media (max-width: 1250px) {
.hero {
min-height: 880px;
}
.hero__container {
min-height: calc(880px - 72px);
}
.services-grid,
.process-grid,
.testimonials-grid {
grid-template-columns: repeat(2, minmax(0, 1fr));
}
.portfolio-grid,
.gallery-grid {
grid-template-columns: repeat(2, minmax(0, 1fr));
}
.footer-grid {
grid-template-columns: repeat(2, minmax(0, 1fr));
}
}
@media (max-width: 980px) {
.container {
width: min(1280px, calc(100% - 56px));
}
.menu-toggle {
display: inline-flex;
}
.nav {
position: absolute;
top: 72px;
right: 0;
width: min(340px, 100%);
padding: 22px;
border: 1px solid var(--border);
border-top: 0;
border-radius: 0 0 var(--radius) var(--radius);
background: rgba(10, 14, 26, 0.98);
flex-direction: column;
align-items: flex-start;
gap: 16px;
opacity: 0;
visibility: hidden;
pointer-events: none;
transform: translateY(-8px);
transition: opacity var(--transition), transform var(--transition), visibility var(--transition);
}
.nav.is-open {
opacity: 1;
visibility: visible;
pointer-events: auto;
transform: translateY(0);
}
.hero {
min-height: 820px;
}
.hero__container {
min-height: calc(820px - 72px);
max-width: 700px;
}
.hero__subtitle {
font-size: 18px;
}
.about__content,
.about__cards,
.contact-layout {
grid-template-columns: 1fr;
}
.differentials-grid {
grid-template-columns: 1fr;
gap: 28px;
}
.process-step h3 {
font-size: 24px;
}
.final-cta {
padding: 112px 0;
}
.final-cta p {
font-size: 18px;
}
.contact-list__value {
font-size: 16px;
}
}
@media (max-width: 680px) {
.container {
width: calc(100% - 40px);
}
.section {
padding: 96px 0;
}
.section__container {
gap: 48px;
}
.site-header {
backdrop-filter: blur(6px);
}
.header__container {
height: 68px;
}
.nav {
top: 68px;
width: 100%;
}
.hero {
min-height: 760px;
padding-top: 68px;
}
.hero__container {
min-height: calc(760px - 68px);
}
.hero__title {
font-size: clamp(2.3rem, 9vw, 3.25rem);
letter-spacing: -0.5px;
}
.hero__subtitle {
margin-bottom: 32px;
font-size: 17px;
}
.btn--lg {
height: 56px;
font-size: 16px;
}
.gallery-grid,
.portfolio-grid,
.services-grid,
.process-grid,
.testimonials-grid,
.footer-grid {
grid-template-columns: 1fr;
}
.testimonial-card blockquote {
min-height: auto;
}
.final-cta h2 {
font-size: clamp(2rem, 8vw, 2.8rem);
}
.final-cta p {
font-size: 17px;
}
.lightbox {
padding: 20px;
}
.lightbox__arrow {
top: auto;
bottom: 20px;
transform: none;
width: 44px;
height: 52px;
font-size: 36px;
}
.lightbox__arrow--prev {
left: 16px;
}
.lightbox__arrow--next {
right: 16px;
}
.lightbox__close {
top: 14px;
right: 14px;
width: 42px;
height: 42px;
}
.lightbox__stage img {
max-height: 66vh;
}
}
@media (prefers-reduced-motion: reduce) {
*,
*::before,
*::after {
animation: none !important;
transition: none !important;
scroll-behavior: auto !important;
}
}