@font-face {
  font-family: 'DM Sans';
  src: url('../fonts/dm-sans-300.ttf') format('truetype');
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'DM Sans';
  src: url('../fonts/dm-sans-400.ttf') format('truetype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'DM Sans';
  src: url('../fonts/dm-sans-400-italic.ttf') format('truetype');
  font-weight: 400;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: 'DM Sans';
  src: url('../fonts/dm-sans-500.ttf') format('truetype');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'DM Sans';
  src: url('../fonts/dm-sans-600.ttf') format('truetype');
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'The Seasons';
  src: url('../fonts/the-seasons.woff') format('woff');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

:root {
  --container-width: 1280px;
  --transition-smooth: 0.3s ease;
  --transition-slow: 0.7s cubic-bezier(0.22, 1, 0.36, 1);
}
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--color-background);
  color: var(--color-foreground);
  font-family: var(--font-body);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
* { box-sizing: border-box; }
a { color: inherit; text-decoration: none; }
img, video { display: block; max-width: 100%; }
button, input, textarea { font: inherit; }
button { cursor: pointer; }
[hidden] { display: none !important; }
.ek-icon { width: 1.125rem; height: 1.125rem; display: inline-block; flex: 0 0 auto; }
.ek-container { width: min(calc(100% - 3rem), var(--container-width)); margin-inline: auto; }
.ek-brand, .ek-section-title, .ek-hero__title, .ek-services__title, .ek-service-card__title, .ek-contact__form-title, .ek-portfolio-card__title, .ek-testimonial-card__headline, .ek-stat__value, .ek-about__quote-text, .ek-video-showcase__title { font-family: var(--font-display); }
.ek-section { padding: 6rem 0; }
.ek-section-kicker, .ek-services__kicker, .ek-stat__label, .ek-portfolio-card__type, .ek-contact-info__label, .ek-footer__nav a, .ek-navbar__link, .ek-navbar__mobile-link { letter-spacing: 0.3em; text-transform: uppercase; font-size: 0.75rem; }
.ek-section-kicker { margin: 0 0 1rem; color: var(--color-accent); }
.ek-section-kicker--light { color: rgba(var(--color-rgb-primary-foreground), 0.7); }
.ek-section-title { margin: 0 0 1rem; font-size: clamp(2.5rem, 5vw, 3.5rem); line-height: 1.08; font-weight: 600; }
.ek-section-title--light { color: var(--color-primary-foreground); }
.ek-section-description, .ek-contact__heading-text, .ek-faq__description, .ek-about__body p, .ek-services__text, .ek-hero__text { margin: 0; color: rgba(var(--color-rgb-muted-foreground), 1); line-height: 1.8; }
.ek-button { display: inline-flex; align-items: center; justify-content: center; gap: 0.75rem; padding: 0.875rem 1.75rem; font-size: 0.75rem; letter-spacing: 0.2em; text-transform: uppercase; transition: background-color var(--transition-smooth), color var(--transition-smooth), border-color var(--transition-smooth), opacity var(--transition-smooth); border: 1px solid transparent; }
.ek-button--accent { background: var(--color-accent); color: var(--color-accent-foreground); }
.ek-button--accent:hover { background: rgba(var(--color-rgb-accent), 0.9); }
.ek-button--ghost { border-color: rgba(var(--color-rgb-primary-foreground), 0.3); color: var(--color-primary-foreground); background: transparent; }
.ek-button--ghost:hover { background: rgba(var(--color-rgb-primary-foreground), 0.1); }
.ek-button--dark { background: var(--color-primary); color: var(--color-primary-foreground); border-radius: 2px; }
.ek-button--dark:hover { background: rgba(var(--color-rgb-primary), 0.9); }
.ek-reveal { opacity: 0; transform: translate3d(0, 30px, 0); transition: opacity var(--transition-slow), transform var(--transition-slow); }
.ek-reveal[data-reveal="zoom-in"] { transform: scale(0.95); }
.ek-reveal.is-visible { opacity: 1; transform: translate3d(0, 0, 0) scale(1); }

.ek-navbar { position: fixed; inset: 0 0 auto; z-index: 50; padding: 1.25rem 0; border-bottom: 1px solid transparent; transition: background-color var(--transition-smooth), backdrop-filter var(--transition-smooth), border-color var(--transition-smooth), padding var(--transition-smooth); }
.ek-navbar.is-scrolled { padding: 0.75rem 0; background: rgba(var(--color-rgb-foreground), 0.95); backdrop-filter: blur(12px); border-color: var(--color-border); }
.ek-navbar__inner { display: flex; align-items: center; justify-content: space-between; }
.ek-navbar__brand, .ek-footer__brand { font-size: clamp(2rem, 2.8vw, 3rem); font-weight: 600; letter-spacing: 0.02em; color: var(--color-primary-foreground); }
.ek-navbar.is-scrolled .ek-navbar__brand { font-size: clamp(1.45rem, 2vw, 2rem); }
.ek-navbar__desktop { display: none; align-items: center; gap: 2rem; }
.ek-navbar__link, .ek-navbar__icon-link { color: var(--color-primary-foreground); transition: color var(--transition-smooth), opacity var(--transition-smooth); }
.ek-navbar.is-scrolled .ek-navbar__link, .ek-navbar.is-scrolled .ek-navbar__icon-link { opacity: 0.72; }
.ek-navbar__link:hover, .ek-navbar__icon-link:hover, .ek-navbar.is-scrolled .ek-navbar__link:hover, .ek-navbar.is-scrolled .ek-navbar__icon-link:hover { opacity: 1; }
.ek-navbar__toggle { display: inline-flex; align-items: center; justify-content: center; width: 2.75rem; height: 2.75rem; border: 0; background: transparent; color: var(--color-primary-foreground); position: relative; }
.ek-navbar__toggle-icon { position: absolute; transition: opacity var(--transition-smooth), transform var(--transition-smooth); }
.ek-navbar__toggle[aria-expanded="true"] .ek-navbar__toggle-icon--menu, .ek-navbar__toggle[aria-expanded="false"] .ek-navbar__toggle-icon--close { opacity: 0; transform: scale(0.85); }
.ek-navbar__mobile { max-height: 0; overflow: hidden; opacity: 0; border-bottom: 1px solid transparent; background: var(--color-background); transition: max-height var(--transition-smooth), opacity var(--transition-smooth), border-color var(--transition-smooth); }
.ek-navbar__mobile.is-open { max-height: 420px; opacity: 1; border-color: var(--color-border); }
.ek-navbar__mobile-inner { display: flex; flex-direction: column; align-items: center; gap: 1.5rem; padding: 2rem 1.5rem; }
.ek-navbar__mobile-link, .ek-navbar__mobile-icon-link { color: rgba(var(--color-rgb-muted-foreground), 1); }
.ek-navbar__mobile-link:hover, .ek-navbar__mobile-icon-link:hover { color: var(--color-accent); }

.ek-hero { position: relative; min-height: 100vh; display: flex; align-items: flex-end; overflow: hidden; }
.ek-hero__media-wrap, .ek-hero__media, .ek-hero__overlay { position: absolute; inset: 0; }
.ek-hero__media { width: 100%; height: 100%; object-fit: cover; }
.ek-hero__overlay { background: linear-gradient(to top, rgba(var(--color-rgb-foreground), 0.8), rgba(var(--color-rgb-foreground), 0.4), rgba(var(--color-rgb-foreground), 0.25)); }
.ek-hero__content { position: relative; z-index: 1; width: 100%; padding-top: 8rem; padding-bottom: 3rem; padding-inline: 1.5rem; box-sizing: border-box; display: flex; flex-direction: column; justify-content: flex-end; }
.ek-hero__content.ek-container { width: 100%; max-width: none; margin-inline: 0; }
.ek-hero__content-inner { max-width: 48rem; margin-inline: 0; margin-right: auto; }
.ek-hero__title { margin: 0 0 1.75rem; font-size: clamp(4rem, 13vw, 9rem); line-height: 0.92; color: var(--color-primary-foreground); font-weight: 600; }
.ek-hero__text { max-width: 36rem; font-size: clamp(1.125rem, 2vw, 1.25rem); color: rgba(var(--color-rgb-primary-foreground), 0.8); }
.ek-hero__actions { display: flex; flex-wrap: wrap; gap: 1rem; margin-top: 2.5rem; }

.ek-about__top-grid, .ek-about__services-grid, .ek-contact__grid, .ek-faq-grid { display: grid; gap: 4rem; }
.ek-about__body { display: grid; gap: 1.25rem; }
.ek-about__quote { margin: 3rem 0 0; padding-top: 2rem; border-top: 1px solid var(--color-border); }
.ek-about__quote-text { margin: 0; font-size: clamp(1.4rem, 2.2vw, 2rem); color: rgba(var(--color-rgb-foreground), 0.8); font-style: italic; line-height: 1.6; }
.ek-about__quote-author { margin: 1.25rem 0 0; color: var(--color-accent); font-size: 0.75rem; letter-spacing: 0.3em; text-transform: uppercase; }
.ek-about-gallery { position: relative; aspect-ratio: 4 / 5; overflow: hidden; }
.ek-about-gallery__slide { position: absolute; inset: 0; opacity: 0; transition: opacity 0.8s ease; }
.ek-about-gallery__slide.is-active { opacity: 1; }
.ek-about-gallery__slide img { width: 100%; height: 100%; object-fit: cover; }
.ek-stats-bar { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 2rem; padding: 3rem 0; margin: 0 0 6rem; border-top: 1px solid var(--color-border); border-bottom: 1px solid var(--color-border); }
.ek-stat { text-align: center; }
.ek-stat__value { margin: 0; font-size: 36px; font-weight: 600; }
.ek-stat__label { margin: 0.5rem 0 0; color: rgba(var(--color-rgb-muted-foreground), 1); }
.ek-services__cards { display: grid; gap: 1.25rem; }
.ek-service-card { padding: 1.75rem; border: 1px solid var(--color-border); border-radius: 0.5rem; background: var(--color-card); box-shadow: 0 2px 10px rgba(var(--color-rgb-foreground), 0.05); transition: background-color var(--transition-smooth), border-color var(--transition-smooth), box-shadow var(--transition-smooth), transform var(--transition-smooth), color var(--transition-smooth); }
.ek-service-card:hover { background: var(--color-secondary); box-shadow: 0 12px 28px rgba(var(--color-rgb-foreground), 0.08); }
.ek-service-card.is-active { background: var(--color-primary); border-color: var(--color-primary); box-shadow: 0 18px 32px rgba(var(--color-rgb-foreground), 0.14); }
.ek-service-card__icon { width: 3rem; height: 3rem; border-radius: 999px; display: inline-flex; align-items: center; justify-content: center; margin-bottom: 1.25rem; background: var(--color-secondary); color: var(--color-accent); }
.ek-service-card.is-active .ek-service-card__icon { background: rgba(var(--color-rgb-primary-foreground), 0.2); color: var(--color-primary-foreground); }
.ek-service-card__title { margin: 0 0 0.75rem; font-size: 1.5rem; font-weight: 600; transition: color var(--transition-smooth); }
.ek-service-card__text { margin: 0; font-size: 0.95rem; line-height: 1.8; color: rgba(var(--color-rgb-muted-foreground), 1); transition: color var(--transition-smooth); }
.ek-service-card.is-active .ek-service-card__title { color: var(--color-primary-foreground); }
.ek-service-card.is-active .ek-service-card__text { color: rgba(var(--color-rgb-primary-foreground), 0.72); }
.ek-services__kicker { display: inline-flex; align-items: center; gap: 0.75rem; margin: 0 0 1rem; color: var(--color-accent); }
.ek-services__line { width: 2rem; height: 1px; display: inline-block; background: var(--color-accent); }
.ek-services__title { margin: 0 0 1.5rem; font-size: clamp(2rem, 3.4vw, 3rem); font-weight: 600; }
.ek-services__text { margin-bottom: 2rem; }
.ek-services__content { display: flex; flex-direction: column; justify-content: center; }
.ek-services__content .ek-button { align-self: flex-start; width: auto; }

.ek-section--portfolio, .ek-section--faq { background: rgba(var(--color-rgb-secondary), 0.3); }
.ek-section--testimonials { background: rgba(var(--color-rgb-secondary), 0.4); }
.ek-section-heading { max-width: 48rem; text-align: center; margin: 0 auto 4rem; }
.ek-section-heading .ek-section-description { max-width: 42rem; margin-inline: auto; }
.ek-portfolio-grid, .ek-testimonials-grid { display: grid; gap: 1.5rem; }
.ek-portfolio-card { display: flex; flex-direction: column; }
.ek-portfolio-card__media-wrap { overflow: hidden; margin-bottom: 1.25rem; }
.ek-portfolio-card__media-wrap img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; transition: transform 0.7s ease; }
.ek-portfolio-card:hover .ek-portfolio-card__media-wrap img { transform: scale(1.05); }
.ek-portfolio-card__type { margin: 0 0 0.25rem; color: var(--color-accent); }
.ek-portfolio-card__title { margin: 0 0 0.25rem; font-size: 2rem; font-weight: 600; }
.ek-portfolio-card__location { margin: 0; color: rgba(var(--color-rgb-muted-foreground), 1); font-size: 0.95rem; }

.ek-video-showcase { position: relative; height: 85vh; min-height: 42rem; overflow: hidden; background: var(--color-foreground); }
.ek-video-showcase__videos, .ek-video-showcase__overlay, .ek-video-showcase__content { position: absolute; inset: 0; }
.ek-video-showcase__video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: 0; transition: opacity 1s ease; }
.ek-video-showcase__video.is-active { opacity: 1; }
.ek-video-showcase__overlay { background: rgba(var(--color-rgb-foreground), 0.4); }
.ek-video-showcase__content { display: flex; align-items: center; justify-content: center; text-align: center; z-index: 2; }
.ek-video-showcase__kicker { margin: 0 0 1rem; font-size: 0.75rem; letter-spacing: 0.35em; text-transform: uppercase; color: rgba(var(--color-rgb-background), 0.6); }
.ek-video-showcase__title { margin: 0 0 0.75rem; font-size: clamp(3rem, 8vw, 8rem); line-height: 1.02; font-weight: 600; color: var(--color-background); }
.ek-video-showcase__subtitle { margin: 0; color: rgba(var(--color-rgb-background), 0.7); letter-spacing: 0.05em; font-size: clamp(1rem, 2vw, 1.25rem); }
.ek-video-showcase__nav { position: absolute; left: 50%; bottom: 2.5rem; z-index: 3; display: flex; align-items: center; gap: 0.75rem; transform: translateX(-50%); }
.ek-video-showcase__nav-item { display: inline-flex; align-items: center; gap: 0.5rem; background: transparent; border: 0; padding: 0; }
.ek-video-showcase__dot { width: 0.5rem; height: 0.5rem; border-radius: 999px; background: rgba(var(--color-rgb-background), 0.4); transition: all 0.5s ease; }
.ek-video-showcase__nav-item:hover .ek-video-showcase__dot { background: rgba(var(--color-rgb-background), 0.7); }
.ek-video-showcase__nav-item.is-active .ek-video-showcase__dot { width: 0.75rem; height: 0.75rem; background: var(--color-background); }
.ek-video-showcase__progress { display: none; width: 4rem; height: 2px; background: rgba(var(--color-rgb-background), 0.2); overflow: hidden; border-radius: 999px; }
.ek-video-showcase__nav-item.is-active .ek-video-showcase__progress { display: block; }
.ek-video-showcase__progress-bar { display: block; width: 0; height: 100%; background: var(--color-background); }

.ek-testimonial-card { display: flex; flex-direction: column; padding: 2.5rem; background: var(--color-card); border-left: 2px solid var(--color-accent); transition: transform var(--transition-smooth), box-shadow var(--transition-smooth), border-color var(--transition-smooth); }
.ek-testimonial-card:hover { transform: translateY(-6px); box-shadow: 0 20px 40px -12px rgba(var(--color-rgb-accent), 0.15); border-left-color: rgba(var(--color-rgb-accent), 0.8); }
.ek-testimonial-card__quote-icon { color: var(--color-accent); margin-bottom: 1.25rem; }
.ek-testimonial-card__quote-icon .ek-icon { width: 1.75rem; height: 1.75rem; }
.ek-testimonial-card__headline { margin: 0 0 1rem; font-size: clamp(1.4rem, 2vw, 2rem); line-height: 1.35; }
.ek-testimonial-card__quote { margin: 0 0 2rem; color: rgba(var(--color-rgb-muted-foreground), 1); line-height: 1.8; flex: 1 1 auto; }
.ek-testimonial-card__meta { display: flex; align-items: center; gap: 1rem; margin-top: auto; }
.ek-testimonial-card__meta img { width: 3.5rem; height: 3.5rem; border-radius: 999px; object-fit: cover; }
.ek-testimonial-card__name { margin: 0; font-weight: 500; }
.ek-testimonial-card__detail { margin: 0.35rem 0 0; color: var(--color-accent); font-size: 0.75rem; }

.ek-faq__intro { position: static; }
.ek-faq__items { display: grid; gap: 0.75rem; }
.ek-faq-item { background: var(--color-card); border: 1px solid var(--color-border); border-radius: 0.5rem; transition: border-color var(--transition-smooth); }
.ek-faq-item.is-open { border-color: rgba(var(--color-rgb-accent), 0.4); }
.ek-faq-item__trigger { width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: 1.25rem 1.5rem; border: 0; background: transparent; text-align: left; color: var(--color-foreground); }
.ek-faq-item__icon { transition: transform 0.2s ease; }
.ek-faq-item.is-open .ek-faq-item__icon { transform: rotate(180deg); }
.ek-faq-item__content { max-height: 0; overflow: hidden; transition: max-height 0.2s ease; }
.ek-faq-item__content p { margin: 0; padding: 0 1.5rem 1.5rem; color: rgba(var(--color-rgb-muted-foreground), 1); line-height: 1.8; }

.ek-section--contact, .ek-footer { background: var(--color-foreground); }
.ek-contact__heading { margin-bottom: 4rem; }
.ek-contact__heading-text, .ek-contact__form-title, .ek-contact-info__value, .ek-contact-info__label, .ek-contact-form label, .ek-contact-form input, .ek-contact-form textarea, .ek-footer__copyright, .ek-footer__credit, .ek-footer__nav a, .ek-footer__brand { color: var(--color-primary-foreground); }
.ek-contact__heading-text { color: rgba(var(--color-rgb-primary-foreground), 0.6); }
.ek-contact__info-list { display: flex; flex-direction: column; gap: 2rem; }
.ek-contact-info { display: flex; align-items: center; gap: 1rem; }
.ek-contact-info__icon { width: 3rem; height: 3rem; border: 1px solid rgba(var(--color-rgb-primary-foreground), 0.2); display: inline-flex; align-items: center; justify-content: center; color: var(--color-accent); transition: border-color var(--transition-smooth); }
.ek-contact-info:hover .ek-contact-info__icon { border-color: var(--color-accent); }
.ek-contact-info__label { display: block; margin-bottom: 0.25rem; color: rgba(var(--color-rgb-primary-foreground), 0.4); }
.ek-contact-info__value { transition: color var(--transition-smooth); }
.ek-contact-info:hover .ek-contact-info__value { color: var(--color-accent); }
.ek-contact__form-title { margin: 0 0 2rem; font-size: clamp(2rem, 3vw, 3rem); }
.ek-contact-form { display: grid; gap: 1.5rem; }
.ek-field-group { display: grid; gap: 0.5rem; }
.ek-contact-form label { font-size: 0.75rem; letter-spacing: 0.2em; text-transform: uppercase; color: rgba(var(--color-rgb-primary-foreground), 0.4); }
.ek-contact-form input, .ek-contact-form textarea { width: 100%; border: 0; border-bottom: 1px solid rgba(var(--color-rgb-primary-foreground), 0.2); padding: 0.75rem 0; background: transparent; color: var(--color-primary-foreground); outline: none; transition: border-color var(--transition-smooth); }
.ek-contact-form input::placeholder, .ek-contact-form textarea::placeholder { color: rgba(var(--color-rgb-primary-foreground), 0.2); }
.ek-contact-form input:focus, .ek-contact-form textarea:focus { border-color: var(--color-accent); }
.ek-contact-form textarea { resize: none; }
.ek-contact-form__actions { padding-top: 1rem; }
.ek-button[disabled] { opacity: 0.6; }
.ek-map { width: 100%; height: 450px; }
.ek-map iframe { width: 100%; height: 100%; display: block; }

.ek-footer { border-top: 1px solid rgba(var(--color-rgb-primary-foreground), 0.1); padding: 4rem 0; }
.ek-footer__inner { display: flex; flex-direction: column; align-items: center; gap: 2.5rem; }
.ek-footer__nav { display: flex; flex-wrap: wrap; justify-content: center; gap: 1.5rem 2.5rem; }
.ek-footer__nav a { color: rgba(var(--color-rgb-primary-foreground), 0.5); transition: color var(--transition-smooth); }
.ek-footer__nav a:hover, .ek-footer__credit a:hover { color: var(--color-accent); }
.ek-footer__meta { width: 100%; display: flex; flex-direction: column; align-items: center; gap: 0.5rem; padding-top: 2rem; border-top: 1px solid rgba(var(--color-rgb-primary-foreground), 0.1); }
.ek-footer__copyright, .ek-footer__credit { margin: 0; text-align: center; font-size: 0.75rem; letter-spacing: 0.08em; }
.ek-footer__copyright { color: rgba(var(--color-rgb-primary-foreground), 0.4); }
.ek-footer__credit { color: rgba(var(--color-rgb-primary-foreground), 0.3); }
.ek-footer__credit a { color: var(--color-accent); transition: color var(--transition-smooth); }

.ek-toast-stack { position: fixed; right: 1.5rem; bottom: 1.5rem; z-index: 100; display: grid; gap: 0.75rem; width: min(22rem, calc(100% - 3rem)); }
.ek-toast { padding: 1rem 1.25rem; background: var(--color-card); border: 1px solid var(--color-border); box-shadow: 0 16px 40px rgba(var(--color-rgb-foreground), 0.12); transform: translateY(1rem); opacity: 0; transition: opacity 0.25s ease, transform 0.25s ease; }
.ek-toast.is-error { border-color: rgba(220, 38, 38, 0.4); }
.ek-toast.is-visible { transform: translateY(0); opacity: 1; }
.ek-toast__title { display: block; margin-bottom: 0.25rem; }
.ek-toast__description { margin: 0; color: rgba(var(--color-rgb-muted-foreground), 1); line-height: 1.6; }

.ek-not-found { min-height: 100vh; display: grid; place-items: center; background: var(--color-muted); }
.ek-not-found__inner { text-align: center; padding: 2rem; }
.ek-not-found__code { margin: 0 0 1rem; font-size: 2.5rem; font-family: var(--font-body); }
.ek-not-found__title { margin: 0 0 1rem; font-size: 1.5rem; color: var(--color-muted-foreground); font-family: var(--font-body); }
.ek-not-found__link { color: var(--color-primary); text-decoration: underline; }

@media (min-width: 768px) {
  .ek-section { padding: 8rem 0; }
  .ek-navbar__desktop { display: flex; }
  .ek-navbar__toggle, .ek-navbar__mobile { display: none; }
  .ek-hero__content { padding-bottom: 4rem; padding-inline: 2.5rem; }
  .ek-about__top-grid, .ek-contact__grid { grid-template-columns: 1fr 1fr; }
  .ek-contact__grid { grid-template-columns: minmax(0, 2fr) minmax(0, 3fr); }
  .ek-about__services-grid, .ek-faq-grid { grid-template-columns: 1fr 1fr; }
  .ek-services__cards { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .ek-stats-bar { grid-template-columns: repeat(4, minmax(0, 1fr)); }
  .ek-portfolio-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .ek-testimonials-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (min-width: 1024px) {
  .ek-services__content { padding-left: 2rem; }
  .ek-faq-grid { grid-template-columns: minmax(0, 1fr) minmax(0, 1.5fr); }
  .ek-faq__intro { position: sticky; top: 8rem; }
}
@media (max-width: 767px) {
  .ek-container { width: min(calc(100% - 2rem), var(--container-width)); }
  .ek-hero__content.ek-container { width: 100%; margin-inline: 0; padding-inline: 1.5rem; }
  .ek-hero__content-inner { padding-bottom: 50px; }
  .ek-hero__actions { flex-wrap: nowrap; }
  .ek-button { width: 100%; }
  .ek-services__content .ek-button { width: auto; }
  .ek-video-showcase { min-height: 34rem; }
  .ek-video-showcase__nav { width: calc(100% - 2rem); justify-content: center; }
  .ek-testimonial-card, .ek-service-card { padding: 2rem; }
}
