:root{
  --bg:#f5f3ef;
  --bg-2:#efe8df;
  --bg-3:#e7dfd4;
  --surface:rgba(255,255,255,.42);
  --surface-strong:rgba(255,255,255,.58);
  --text:#141311;
  --text-soft:#48413b;
  --dark:#111111;
  --dark-soft:#1b1a18;
  --line:rgba(20,19,17,.1);
  --line-light:rgba(255,255,255,.12);
  --accent:#ccb79a;
  --shadow:0 30px 80px rgba(18,16,14,.12), 0 12px 32px rgba(18,16,14,.08), inset 0 1px 0 rgba(255,255,255,.32);
  --shadow-soft:0 18px 40px rgba(20,18,16,.08), inset 0 1px 0 rgba(255,255,255,.26);
  --radius:28px;
  --radius-sm:18px;
  --ease:cubic-bezier(0.22, 1, 0.36, 1);
  --max:1280px;
}

*,
*::before,
*::after{
  box-sizing:border-box;
}

html{
  scroll-behavior:smooth;
}

body{
  margin:0;
  color:var(--text);
  background:
    radial-gradient(circle at 20% 0%, rgba(207,188,160,.22), transparent 28%),
    radial-gradient(circle at 80% 16%, rgba(255,255,255,.4), transparent 26%),
    linear-gradient(180deg, #f8f5f0 0%, #f1ece5 100%);
  font-family:"Maven Pro", sans-serif;
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

img{
  display:block;
  width:100%;
  height:auto;
}

a{
  color:inherit;
  text-decoration:none;
}

button{
  font:inherit;
}

.page-noise{
  position:fixed;
  inset:0;
  pointer-events:none;
  opacity:.05;
  background-image:
    radial-gradient(circle at 1px 1px, rgba(17,17,17,.45) 1px, transparent 0);
  background-size:20px 20px;
  mix-blend-mode:multiply;
}

.shell{
  width:min(calc(100% - 40px), var(--max));
  margin:0 auto;
}

.narrow{
  width:min(calc(100% - 40px), 920px);
}

.center{
  text-align:center;
}

.scene{
  position:relative;
  padding:100px 0;
}

.scene-light{
  background:transparent;
}

.scene-warm{
  background:
    linear-gradient(180deg, rgba(240,236,230,.95), rgba(232,224,214,.94));
}

.scene-deep{
  color:#f4f0eb;
  background:
    radial-gradient(circle at 20% 0%, rgba(184,153,117,.12), transparent 24%),
    radial-gradient(circle at 80% 100%, rgba(255,255,255,.04), transparent 22%),
    linear-gradient(180deg, #151412 0%, #0f0f0e 100%);
}

.scene-contrast{
  color:#f2eee8;
  background:
    radial-gradient(circle at 10% 10%, rgba(200,180,150,.11), transparent 25%),
    radial-gradient(circle at 85% 90%, rgba(255,255,255,.03), transparent 20%),
    linear-gradient(180deg, #161514 0%, #0d0d0c 100%);
}

.headline{
  margin:0;
  letter-spacing:-0.03em;
  line-height:.98;
}

.headline .sans{
  font-family:"Jost", sans-serif;
  font-weight:600;
  font-style:normal;
}

.headline .serif{
  font-family:"Vollkorn", serif;
  font-style:italic;
  font-weight:400;
}

.section-title{
  font-size:clamp(2.3rem, 5vw, 4.7rem);
  max-width:12ch;
}

.body-large,
.lead{
  font-size:clamp(1.05rem, 1.6vw, 1.24rem);
  line-height:1.75;
  color:var(--text-soft);
}

.hero .lead{
  font-size:clamp(1.05rem, 1.6vw, 1.24rem);
  line-height:1.75;
  color:#f4f0eb;
}

.scene-deep .body-large,
.scene-deep .lead,
.scene-contrast .lead{
  color:rgba(244,240,235,.76);
}

.eyebrow{
  margin:0 0 16px;
  font-size:.82rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  opacity:.72;
}

.button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:52px;
  padding:0 22px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.2);
  background:
    linear-gradient(180deg, rgba(255,255,255,.24), rgba(255,255,255,.1)),
    linear-gradient(180deg, #1f1c19 0%, #131211 100%);
  color:#f5efe7;
  box-shadow:
    0 12px 26px rgba(0,0,0,.22),
    inset 0 1px 0 rgba(255,255,255,.22),
    inset 0 -1px 0 rgba(0,0,0,.22);
  transition:transform .5s var(--ease), box-shadow .5s var(--ease), background .5s var(--ease);
  white-space:nowrap;
}

.button:hover{
  transform:translateY(-2px);
  box-shadow:
    0 18px 36px rgba(0,0,0,.24),
    inset 0 1px 0 rgba(255,255,255,.24),
    inset 0 -1px 0 rgba(0,0,0,.24);
}

.button-large{
  min-height:58px;
  padding:0 28px;
}

.site-header{
  position:fixed;
  top:0;
  left:0;
  width:100%;
  z-index:50;
  padding:18px 0;
  transform:translateY(0);
  transition:transform .7s var(--ease), background .7s var(--ease), backdrop-filter .7s var(--ease), border-color .7s var(--ease);
}

.site-header.scrolled{
  /*
  background:rgba(245,243,239,.62);
  backdrop-filter:blur(18px) saturate(120%);
  border-bottom:1px solid rgba(20,19,17,.06);
  */
}

.site-header.hidden{
  transform:translateY(-110%);
}

.header-inner{
  display:grid;
  grid-template-columns:auto 1fr auto auto;
  align-items:center;
  gap:24px;
  padding:10px 18px 10px 35px;
  border-radius:999px;
  background:rgba(255,255,255,.18);
  border:1px solid rgba(255,255,255,.22);
  backdrop-filter:blur(16px);
  box-shadow:var(--shadow-soft);
}

.scrolled .header-inner{
  background:rgba(255,255,255,.6);
}

.brand{
  display:flex;
  align-items:center;
  width:170px;
}

.brand img{
  width:100%;
  height:auto;
}

.main-nav{
  display:flex;
  gap:26px;
  justify-content:center;
  font-size:.95rem;
}

.main-nav a,
.footer-links a,
.footer-contact a,
.contact-direct a{
  position:relative;
}

.main-nav a::after,
.footer-links a::after,
.footer-contact a::after,
.contact-direct a::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:-5px;
  height:1px;
  transform:scaleX(0);
  transform-origin:left;
  background:currentColor;
  transition:transform .5s var(--ease);
}

.main-nav a:hover::after,
.footer-links a:hover::after,
.footer-contact a:hover::after,
.contact-direct a:hover::after{
  transform:scaleX(1);
}

.nav-toggle{
  display:none;
  width:50px;
  height:50px;
  border-radius:50%;
  border:1px solid rgba(20,19,17,.08);
  background:rgba(255,255,255,.4);
  backdrop-filter:blur(10px);
  align-items:center;
  justify-content:center;
  flex-direction:column;
  gap:6px;
  cursor:pointer;
}

.nav-toggle span{
  width:18px;
  height:1.5px;
  background:#141311;
  display:block;
  transition:transform .45s var(--ease), opacity .45s var(--ease);
}

.nav-toggle.active span:first-child{
  transform:translateY(3.75px) rotate(45deg);
}

.nav-toggle.active span:last-child{
  transform:translateY(-3.75px) rotate(-45deg);
}

.mobile-menu{
  display:none;
  width:min(calc(100% - 24px), 520px);
  margin:12px auto 0;
  padding:16px;
  border-radius:26px;
  background:rgba(255,255,255,.66);
  backdrop-filter:blur(16px);
  border:1px solid rgba(255,255,255,.34);
  box-shadow:var(--shadow-soft);
}

.mobile-menu.open{
  display:grid;
  gap:12px;
}

.hero{
  min-height:100svh;
  display:flex;
  align-items:center;
  padding-top:150px;
  overflow:hidden;
}

.hero-backdrop{
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 18% 18%, rgba(255,255,255,.08), transparent 22%),
    radial-gradient(circle at 82% 18%, rgba(204,183,154,.16), transparent 26%),
    linear-gradient(180deg, #111111 0%, #161412 48%, #1d1915 100%);
}

.hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg, rgba(17,17,17,.82), rgba(17,17,17,.35) 42%, rgba(17,17,17,.08) 74%),
    linear-gradient(180deg, rgba(255,255,255,.02), transparent 60%);
}

.hero-grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:minmax(0, 1.05fr) minmax(320px, 800px);
  align-items:center;
  gap:54px;
}

.hero-copy{
  color:#f4f0eb;
  max-width:640px;
}

.hero-title{
  font-size:clamp(3rem, 7vw, 3rem);
  max-width:10ch;
}

.hero .lead{
  margin:26px 0 0;
  max-width:56ch;
}

.hero-actions{
  margin-top:34px;
}

.hero-figure{
  margin:0;
  justify-self:end;
  width:min(100%, 800px);
}

.hero-image-frame{
  position:relative;
  width:100%;
  max-width:800px;
  aspect-ratio:3 / 2;
  overflow:hidden;
  border-radius:34px;
  border:1px solid rgba(255,255,255,.12);
  box-shadow:
    0 40px 120px rgba(0,0,0,.42),
    inset 0 1px 0 rgba(255,255,255,.2);
  background:rgba(255,255,255,.04);
}

.hero-image-frame::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:2;
  background:
    linear-gradient(180deg, rgba(255,255,255,.14), transparent 28%),
    linear-gradient(0deg, rgba(0,0,0,.18), transparent 26%);
  pointer-events:none;
}

.hero-image-frame img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center center;
  transform:scale(1.04);
  transition:transform 1.4s var(--ease);
}

.hero:hover .hero-image-frame img{
  transform:scale(1.07);
}

figcaption {
	display:none!important;
}

.hero figcaption{
  margin-top:16px;
  max-width:48ch;
  color:rgba(244,240,235,.62);
  font-size:.92rem;
}

.usp{
  padding-top:78px;
  padding-bottom:86px;
}

.usp-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:18px;
  margin-top:34px;
}

.usp-item{
  padding:28px 26px;
  border-radius:24px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.56), rgba(255,255,255,.34));
  border:1px solid rgba(255,255,255,.45);
  box-shadow:var(--shadow-soft);
  min-height:150px;
  display:flex;
  align-items:flex-end;
}

.usp-item p{
  margin:0;
  font-size:1.06rem;
  line-height:1.6;
}

.local-context{
  overflow:hidden;
}

.context-pattern{
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg, transparent 0, rgba(20,19,17,.04) 49.5%, transparent 50.5%) center/80px 100%,
    radial-gradient(circle at 20% 20%, rgba(255,255,255,.3), transparent 18%),
    radial-gradient(circle at 80% 80%, rgba(20,19,17,.05), transparent 18%);
  mask-image:linear-gradient(180deg, transparent, black 10%, black 90%, transparent);
  opacity:.9;
}

.local-context blockquote {
	border-radius:22px!important;
}

.local-context .section-title{
  max-width:11ch;
}

.gallery{
  display:grid;
  grid-template-columns:repeat(24, minmax(0, 1fr));
  grid-auto-rows:14px;
  gap:16px;
  width:100%;
  padding:20px;
  overflow:hidden;
}

.gallery-rail{
  display:contents;
}

.gallery-row-a,
.gallery-row-b,
.gallery-row-c,
.gallery-row-d{
  transform:none;
}

.gallery-card{
  position:relative;
  margin:0;
  overflow:hidden;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.08);
  background:#1c1b18;
  cursor:pointer;
  box-shadow:0 14px 40px rgba(0,0,0,.25);
  transform:translateY(0);
  transition:transform .8s var(--ease), box-shadow .8s var(--ease), filter .8s var(--ease);
  min-width:0;

  grid-column:span 8;
  grid-row:span 18;
  height:100%;
}

.gallery-card.wide{
  grid-column:span 8;
  grid-row:span 8;
}

.gallery-card.tall{
  grid-row:span 24;
}

.gallery-card img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform 1.2s var(--ease), filter 1.2s var(--ease);
}

.gallery-card::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, transparent 48%, rgba(0,0,0,.36));
  opacity:.62;
  transition:opacity .8s var(--ease);
}

.gallery-card figcaption{
  position:absolute;
  left:18px;
  right:18px;
  bottom:16px;
  z-index:2;
  margin:0;
  font-size:.9rem;
  line-height:1.45;
  color:rgba(244,240,235,.86);
}

.gallery-card:hover{
  transform:translateY(-6px);
  box-shadow:0 24px 60px rgba(0,0,0,.32);
}

.gallery-card:hover img{
  transform:scale(1.045);
  filter:saturate(1.04);
}

@media (max-width: 1100px){
  .gallery{
    grid-template-columns:repeat(8, minmax(0, 1fr));
  }

  .gallery-card{
    grid-column:span 2;
  }

  .gallery-card.wide{
    grid-column:span 4;
  }
}

@media (max-width: 720px){
  .gallery{
    grid-template-columns:repeat(2, minmax(0, 1fr));
    grid-auto-rows:12px;
    padding:0 12px;
  }

  .gallery-card{
    grid-column:span 1;
    grid-row:span 18;
  }

  .gallery-card.wide{
    grid-column:span 2;
    grid-row:span 18;
  }

  .gallery-card.tall{
    grid-row:span 22;
  }
}

@media (max-width: 520px){
  .gallery{
    grid-template-columns:1fr;
  }

  .gallery-card,
  .gallery-card.wide,
  .gallery-card.tall{
    grid-column:span 1;
    grid-row:span 22;
  }
}

.youtube-embed{
  overflow:hidden;
}

.video-glow{
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 25% 20%, rgba(204,183,154,.1), transparent 22%),
    radial-gradient(circle at 80% 70%, rgba(255,255,255,.05), transparent 20%);
}

.video-shell{
  position:relative;
  padding:42px;
  border-radius:34px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 26px 70px rgba(0,0,0,.28), inset 0 1px 0 rgba(255,255,255,.08);
}

.video-shell .section-title{
  max-width:11ch;
  margin-bottom:28px;
}

.video-frame{
  position:relative;
  overflow:hidden;
  border-radius:28px;
  aspect-ratio:16 / 9;
  background:#000;
}

.video-frame iframe{
  width:100%;
  height:100%;
}

.combined-media{
  overflow:hidden;
}

.combined-header{
  margin-bottom:30px;
}

.combined-header .section-title{
  max-width:13ch;
}

.combined-grid{
  display:grid;
  grid-template-columns:1.18fr .82fr;
  gap:22px;
  align-items:start;
}

.comparison-card,
.timelapse-card{
  margin:0;
  padding:18px;
  border-radius:30px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.6), rgba(255,255,255,.34));
  border:1px solid rgba(255,255,255,.4);
  box-shadow:var(--shadow);
}

.comparison-slider,
.timelapse-frame{
  position:relative;
  width:100%;
  padding-bottom:66.667%;
  border-radius:22px;
  overflow:hidden;
  background:#1b1a18;
}

.comparison-after,
.comparison-before{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
}

.comparison-after{
  z-index:1;
}

.comparison-before-wrap{
  position:absolute;
  inset:0;
  z-index:2;
  clip-path:inset(0 50% 0 0);
}

.comparison-before{
  z-index:2;
}

.comparison-handle{
  position:absolute;
  top:0;
  left:50%;
  z-index:3;
  width:2px;
  height:100%;
  transform:translateX(-50%);
  background:rgba(255,255,255,.75);
  box-shadow:0 0 0 1px rgba(0,0,0,.08);
}

.comparison-handle span{
  position:absolute;
  top:50%;
  left:50%;
  width:58px;
  height:58px;
  transform:translate(-50%,-50%);
  border-radius:50%;
  background:
    linear-gradient(180deg, rgba(255,255,255,.62), rgba(255,255,255,.28));
  backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.54);
  box-shadow:0 14px 30px rgba(0,0,0,.16), inset 0 1px 0 rgba(255,255,255,.4);
}

.comparison-handle span::before,
.comparison-handle span::after{
  content:"";
  position:absolute;
  top:50%;
  width:10px;
  height:10px;
  border-top:2px solid #111;
  border-right:2px solid #111;
}

.comparison-handle span::before{
  left:18px;
  transform:translateY(-50%) rotate(-135deg);
}

.comparison-handle span::after{
  right:18px;
  transform:translateY(-50%) rotate(45deg);
}

.timelapse-frame img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
}

.comparison-card figcaption,
.timelapse-card figcaption{
  margin-top:14px;
  font-size:.92rem;
  color:var(--text-soft);
}

.problem-grid{
  display:grid;
  grid-template-columns:minmax(0, 1.2fr) minmax(200px, .8fr);
  gap:40px;
  align-items:center;
}

.decorative-block{
  min-height:320px;
  border-radius:34px;
  background:
    radial-gradient(circle at 30% 30%, rgba(255,255,255,.32), transparent 22%),
    linear-gradient(180deg, rgba(255,255,255,.34), rgba(255,255,255,.14));
  border:1px solid rgba(255,255,255,.38);
  box-shadow:var(--shadow-soft);
  position:relative;
  overflow:hidden;
}

.decorative-lines{
  position:absolute;
  inset:18px;
  border-radius:24px;
  border:1px solid rgba(20,19,17,.1);
  background:
    linear-gradient(90deg, rgba(20,19,17,.05) 1px, transparent 1px) center/32px 32px,
    linear-gradient(180deg, rgba(20,19,17,.05) 1px, transparent 1px) center/32px 32px;
}

.benefits-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:18px;
  margin-top:34px;
}

.benefit-card{
  padding:28px;
  border-radius:28px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.64), rgba(255,255,255,.38));
  border:1px solid rgba(255,255,255,.44);
  box-shadow:var(--shadow-soft);
}

.benefit-icon{
  width:48px;
  height:48px;
  display:grid;
  place-items:center;
  border-radius:16px;
  margin-bottom:18px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.7), rgba(255,255,255,.34));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.3), 0 12px 24px rgba(20,19,17,.06);
}

.benefit-icon svg{
  width:24px;
  height:24px;
  fill:none;
  stroke:#111;
  stroke-width:1.8;
  stroke-linecap:round;
  stroke-linejoin:round;
}

.benefit-card h3{
  margin:0 0 12px;
  font-size:1.22rem;
  line-height:1.2;
}

.benefit-card p{
  margin:0;
  line-height:1.7;
  color:var(--text-soft);
}

.feature-layout{
  display:grid;
  grid-template-columns:.75fr 1.25fr;
  gap:34px;
  align-items:start;
}

.feature-list{
  display:grid;
  gap:14px;
}

.feature-list article{
  padding:24px 24px 22px;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.1);
  background:
    linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06);
}

.feature-list p{
  margin:0;
  font-size:1.06rem;
  line-height:1.65;
  color:rgba(244,240,235,.8);
}

.about-grid{
  display:grid;
  grid-template-columns:minmax(260px, 360px) minmax(0,1fr);
  gap:44px;
  align-items:center;
}

.about-portrait{
  margin:0;
  max-width:360px;
  justify-self:start;
}

.about-portrait img{
  border-radius:28px;
  box-shadow:var(--shadow);
}

.about-copy p{
  margin:22px 0 0;
  max-width:60ch;
  font-size:1.08rem;
  line-height:1.8;
  color:var(--text-soft);
}

.drone-head{
  display:grid;
  grid-template-columns:minmax(0,.8fr) minmax(0,1.2fr);
  gap:28px;
  align-items:end;
  margin-bottom:28px;
}

.drone-head p{
  margin:0;
  color:var(--text-soft);
  line-height:1.75;
}

.drone-carousel-wrap{
  position:relative;
}

.drone-carousel{
  display:grid;
  grid-auto-flow:column;
  grid-auto-columns:minmax(260px, 400px);
  gap:18px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  padding:8px 56px;
  scrollbar-width:none;
}

.drone-carousel::-webkit-scrollbar{
  display:none;
}

.drone-card{
  margin:0;
  max-width:400px;
  width:100%;
  scroll-snap-align:center;
  overflow:hidden;
  border-radius:26px;
  aspect-ratio:4 / 4;
  cursor:pointer;
}

.drone-card img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform 1s var(--ease);
}

.drone-card:hover img{
  transform:scale(1.04);
}

.carousel-button{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  z-index:3;
  width:44px;
  height:44px;
  border:none;
  border-radius:50%;
  background:rgba(255,255,255,.72);
  backdrop-filter:blur(12px);
  box-shadow:0 10px 26px rgba(20,19,17,.12);
  cursor:pointer;
  display:grid;
  place-items:center;
  font-size:1.5rem;
}

.carousel-button.prev{left:0;}
.carousel-button.next{right:0;}

.faq-layout{
  display:grid;
  grid-template-columns:minmax(0,.72fr) minmax(0,1.28fr);
  gap:36px;
}

.faq-list{
  display:grid;
  gap:12px;
}

.faq-item{
  border-radius:22px;
  border:1px solid rgba(255,255,255,.1);
  background:
    linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.015));
  overflow:hidden;
}

.faq-item summary{
  list-style:none;
  cursor:pointer;
  padding:22px 24px;
  font-size:1.06rem;
  line-height:1.45;
  color:#f4f0eb;
  position:relative;
}

.faq-item summary::-webkit-details-marker{
  display:none;
}

.faq-item summary::after{
  content:"+";
  position:absolute;
  right:24px;
  top:50%;
  transform:translateY(-50%);
  font-size:1.4rem;
  opacity:.72;
  transition:transform .45s var(--ease);
}

.faq-item[open] summary::after{
  transform:translateY(-50%) rotate(45deg);
}

.faq-item p{
  margin:0;
  padding:0 24px 22px;
  color:rgba(244,240,235,.74);
  line-height:1.72;
}

.cta{
  overflow:hidden;
}

.cta h2, .contact h2 {
	margin:0 auto;
}

.cta-pattern,
.contact-pattern{
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 20% 20%, rgba(255,255,255,.28), transparent 18%),
    radial-gradient(circle at 80% 80%, rgba(20,19,17,.05), transparent 18%),
    linear-gradient(90deg, rgba(20,19,17,.04) 1px, transparent 1px) center/46px 46px,
    linear-gradient(180deg, rgba(20,19,17,.04) 1px, transparent 1px) center/46px 46px;
  mask-image:linear-gradient(180deg, transparent, black 12%, black 88%, transparent);
}

#lightboxCaption {
	display:none!important;
}

.contact-direct{
  display:flex;
  flex-direction:column;
  gap:16px;
  margin-top:26px;
  font-size:clamp(1.2rem, 2vw, 1.7rem);
}

.site-footer{
  padding:42px 0 54px;
}

.footer-grid{
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:28px;
  align-items:center;
}

.footer-brand{
  width:160px;
}

.footer-contact,
.footer-links{
  display:flex;
  gap:22px;
  flex-wrap:wrap;
}

.footer-contact{
  justify-content:center;
}

.footer-links{
  justify-content:flex-end;
}

.lightbox{
  position:fixed;
  inset:0;
  z-index:90;
  display:grid;
  place-items:center;
  padding:24px;
  background:rgba(10,10,10,.86);
  backdrop-filter:blur(12px);
  opacity:0;
  visibility:hidden;
  transition:opacity .5s var(--ease), visibility .5s var(--ease);
}

.lightbox.open{
  opacity:1;
  visibility:visible;
}

.lightbox-inner{
  max-width:min(92vw, 1200px);
  max-height:86vh;
}

.lightbox-inner img{
  max-width:100%;
  max-height:78vh;
  object-fit:contain;
  border-radius:22px;
  box-shadow:0 34px 90px rgba(0,0,0,.4);
}

.lightbox-inner p{
  margin:16px auto 0;
  max-width:70ch;
  text-align:center;
  color:rgba(255,255,255,.8);
  line-height:1.6;
}

.lightbox-close{
  position:absolute;
  top:22px;
  right:22px;
  width:48px;
  height:48px;
  border:none;
  border-radius:50%;
  background:rgba(255,255,255,.12);
  color:#fff;
  font-size:2rem;
  line-height:1;
  cursor:pointer;
}

.reveal{
  opacity:0;
  transform:translateY(38px);
  transition:opacity 1s var(--ease), transform 1s var(--ease);
}

.reveal.in-view{
  opacity:1;
  transform:translateY(0);
}

.parallax{
  will-change:transform;
}

.visually-hidden{
  position:absolute !important;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

@media (max-width: 1120px){
  .hero-grid,
  .problem-grid,
  .feature-layout,
  .faq-layout,
  .drone-head,
  .about-grid,
  .combined-grid{
    grid-template-columns:1fr;
  }

  .hero-figure{
    justify-self:start;
  }

  .footer-grid{
    grid-template-columns:1fr;
    justify-items:start;
  }

  .footer-contact,
  .footer-links{
    justify-content:flex-start;
  }
}

@media (max-width: 920px){
  .main-nav,
  .header-cta{
    display:none;
  }

  .nav-toggle{
    display:flex;
    justify-self:end;
  }

  .header-inner{
    grid-template-columns:auto 1fr auto;
  }

  .usp-grid,
  .benefits-grid{
    grid-template-columns:1fr;
  }

  .scene{
    padding:86px 0;
  }

  .hero{
    min-height:auto;
    padding-top:128px;
  }

  .gallery-rail{
    grid-auto-columns:minmax(160px, 40vw);
  }

  .gallery-card.wide{
    aspect-ratio:6 / 5;
  }
}

@media (max-width: 640px){
  .shell,
  .narrow{
    width:min(calc(100% - 24px), var(--max));
  }

  .header-inner{
    padding:10px 12px;
    gap:16px;
  }

  .brand{
    width:146px;
  }

  .hero-title{
    font-size:clamp(2.5rem, 13vw, 4.2rem);
  }

  .section-title{
    max-width:100%;
  }

  .video-shell,
  .comparison-card,
  .timelapse-card,
  .benefit-card,
  .usp-item{
    padding:18px;
  }

  .drone-carousel{
    padding:8px 42px;
    grid-auto-columns:minmax(220px, 78vw);
  }

  .carousel-button{
    width:38px;
    height:38px;
  }

  .gallery-rail{
    grid-auto-columns:minmax(150px, 56vw);
    gap:12px;
    padding:0 12px;
  }

  .gallery-row-a,
  .gallery-row-b,
  .gallery-row-c,
  .gallery-row-d{
    transform:none;
  }
}