*{
  box-sizing:border-box;
}

:root{
  --bg:#05080b;
  --bg-soft:#0a0f14;
  --brand:#8EDCFF;
  --brand-dark:#0B0F12;
  --brand-glow:#BFEFFF;
  --line:rgba(142,220,255,.16);
  --max:1200px;
  --muted:#b7c6d1;
  --panel:#11171d;
  --panel-2:#0d1318;
  --radius:18px;
  --shadow:0 12px 32px rgba(0,0,0,.35), 0 0 28px rgba(142,220,255,.08);
  --text:#eef7ff;
}

a{
  color:inherit;
  text-decoration:none;
}

body{
  background:
    radial-gradient(circle at top, rgba(142,220,255,.07), transparent 30%),
    linear-gradient(180deg, #020406 0%, #060a0d 34%, #05080b 100%);
  color:var(--text);
  font-family:Inter,Arial,Helvetica,sans-serif;
  line-height:1.6;
  margin:0;
}

html{
  scroll-behavior:smooth;
}

img{
  display:block;
  max-width:100%;
}

.about-copy{
  margin:0 auto 28px;
  max-width:850px;
  text-align:center;
}

.about-copy p{
  color:var(--muted);
  margin:0 auto 14px;
  max-width:760px;
}

.about-copy p:last-child{
  margin-bottom:0;
}

.about-why{
  margin:0 auto;
  max-width:900px;
}

.brand img{
  background:transparent;
  width:250px;
}

.btn{
  align-items:center;
  border:1px solid rgba(142,220,255,.24);
  border-radius:12px;
  display:inline-flex;
  font-weight:800;
  justify-content:center;
  letter-spacing:.01em;
  min-height:48px;
  padding:0 18px;
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease;
}

.btn:hover{
  transform:translateY(-1px);
}

.btn-primary{
  background:var(--brand);
  box-shadow:0 0 0 1px rgba(255,255,255,.05) inset, 0 0 18px rgba(142,220,255,.28);
  color:var(--brand-dark);
}

.btn-primary:hover{
  background:var(--brand-glow);
}

.btn-secondary{
  background:rgba(5,8,11,.65);
  color:var(--text);
}

.card{
  background:linear-gradient(180deg, rgba(18,24,30,.94), rgba(10,14,18,.98));
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  overflow:hidden;
}

.card h3{
  font-size:1.35rem;
  margin:0 0 10px;
}

.card p{
  color:var(--muted);
  line-height:1.7;
  margin:0 0 18px;
}

.card-body{
  padding:28px;
}

.card:hover .media img{
  transform:scale(1.04);
}

.carousel{
  border:1px solid rgba(142, 220, 255, 0.25);
  border-radius:18px;
  box-shadow:0 0 30px rgba(142, 220, 255, 0.12);
  margin:20px auto 0;
  max-width:1000px;
  overflow:hidden;
  position:relative;
}

.carousel-arrow,
.lightbox-arrow,
.lightbox-close{
  background:rgba(5, 8, 11, 0.75);
  border:1px solid rgba(142, 220, 255, 0.35);
  color:#8EDCFF;
  cursor:pointer;
  position:absolute;
  z-index:5;
}

.carousel-arrow,
.lightbox-arrow{
  border-radius:50%;
  font-size:24px;
  height:46px;
  top:50%;
  transform:translateY(-50%);
  width:46px;
}

.carousel-caption,
.lightbox-caption{
  -webkit-backdrop-filter:blur(6px);
  backdrop-filter:blur(6px);
  background:rgba(255, 255, 255, 0.10);
  bottom:0;
  color:#fff;
  left:0;
  padding:18px 24px;
  position:absolute;
  right:0;
  text-align:left;
}

.carousel-track{
  display:flex;
  transition:transform 0.35s ease;
}

.carousel-track img{
  cursor:pointer;
  height:560px;
  min-width:100%;
  object-fit:cover;
}

.container{
  margin:0 auto;
  width:min(var(--max), calc(100% - 32px));
}

.contact-card{
  background:rgba(255,255,255,.02);
  border:1px solid var(--line);
  border-radius:16px;
  padding:20px;
}

.contact-cards{
  display:grid;
  gap:18px;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  margin-top:20px;
}

.cta-banner{
  background:
    linear-gradient(180deg, rgba(5,8,11,.62), rgba(5,8,11,.82)),
    var(--cta-image) 65% 32% / cover no-repeat;
  border:1px solid var(--line);
  border-radius:22px;
  box-shadow:var(--shadow);
  margin:72px auto 0;
  padding:28px 42px;
  width:min(1180px, calc(100% - 64px));
}

.cta-banner > .container{
  margin:0;
  max-width:700px;
  width:100%;
}

.cta-banner h2{
  font-size:clamp(1.8rem, 3vw, 2.6rem);
  margin:0 0 10px;
}

.cta-banner p{
  color:#dce9f2;
  margin:0 0 18px;
  max-width:620px;
}

.divider{
  background:linear-gradient(90deg, transparent, var(--brand), transparent);
  box-shadow:0 0 16px rgba(142,220,255,.38);
  height:2px;
  margin:0 auto 18px;
  width:110px;
}

.field{
  display:grid;
  gap:8px;
}

.field input,
.field textarea,
.field select{
  background:#0a0e12;
  border:1px solid rgba(142,220,255,.18);
  border-radius:14px;
  color:#eef7ff;
  outline:none;
  padding:14px;
  width:100%;
}

.field label{
  color:#dcebf4;
  font-weight:700;
}

.field textarea{
  min-height:170px;
  resize:vertical;
}

.footer-inner{
  align-items:center;
  display:flex;
  flex-wrap:wrap;
  gap:18px;
  justify-content:space-between;
}

.footer-links{
  display:flex;
  flex-wrap:wrap;
  gap:16px;
}

.form-grid{
  display:grid;
  gap:16px;
  grid-template-columns:repeat(2, minmax(0, 1fr));
}

.gallery{
  display:grid;
  gap:20px;
  grid-template-columns:repeat(3, minmax(0, 1fr));
}

.gallery figcaption{
  background:rgba(0,0,0,.28);
  border-top:1px solid rgba(142,220,255,.10);
  color:#dbe8f0;
  font-weight:700;
  padding:14px 16px;
}

.gallery figure{
  background:#0b1014;
  border:1px solid var(--line);
  border-radius:18px;
  box-shadow:var(--shadow);
  margin:0;
  overflow:hidden;
}

.gallery img{
  height:280px;
  object-fit:cover;
  width:100%;
}

.gallery-section{
  padding:48px 20px;
  text-align:center;
}

.grid{
  display:grid;
  gap:22px;
}

.grid-2{
  grid-template-columns:repeat(2, minmax(0, 1fr));
}

.grid-3{
  grid-template-columns:repeat(3, minmax(0, 1fr));
}

.header-inner{
  align-items:center;
  display:flex;
  gap:18px;
  justify-content:space-between;
  min-height:86px;
}

.hero{
  border-bottom:1px solid var(--line);
  display:grid;
  min-height:300px;
  overflow:hidden;
  place-items:center;
  position:relative;
}

.hero h1{
  font-size:clamp(2.5rem, 5vw, 1.5rem);
  line-height:1.05;
  margin:12px 0;
  margin-inline:auto;
  max-width:1200px;
}

.hero p{
  color:#dce9f2;
  font-size:1rem;
  line-height:1.5;
  margin:0 auto;
  max-width:700px;
}

.hero::after{
  background:linear-gradient(180deg, transparent, rgba(5,8,11,1));
  content:"";
  height:220px;
  inset:auto 0 0 0;
  position:absolute;
}

.hero::before{
  background:linear-gradient(180deg, rgba(0,0,0,.55), rgba(0,0,0,.42) 32%, rgba(0,0,0,.76)), var(--hero-image) center/cover no-repeat;
  content:"";
  inset:0;
  position:absolute;
  transform:scale(1.02);
}

.hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  justify-content:center;
  margin-top:18px;
}

.hero-content{
  max-width:1400px;
  padding:40px 20px 50px;
  position:relative;
  text-align:center;
  width:calc(100% - 48px);
  z-index:1;
}

.kicker{
  background:rgba(142,220,255,.08);
  border:1px solid rgba(142,220,255,.18);
  border-radius:999px;
  color:var(--brand-glow);
  display:inline-block;
  font-size:.92rem;
  font-weight:800;
  letter-spacing:.08em;
  padding:6px 12px;
  text-transform:uppercase;
}

.lightbox{
  align-items:center;
  background:rgba(0,0,0,0.92);
  display:none;
  inset:0;
  justify-content:center;
  position:fixed;
  z-index:9999;
}

.lightbox img{
  max-height:82vh;
  max-width:90vw;
  object-fit:contain;
}

.lightbox-close{
  border-radius:50%;
  font-size:28px;
  height:44px;
  right:24px;
  top:24px;
  width:44px;
}

.lightbox.open{
  display:flex;
}

.list{
  display:grid;
  gap:12px;
  list-style:none;
  margin:18px 0 0;
  padding:0;
}

.list li{
  color:var(--muted);
  padding-left:28px;
  position:relative;
}

.list li::before{
  background:var(--brand);
  border-radius:50%;
  box-shadow:0 0 10px rgba(142,220,255,.8);
  content:"";
  height:10px;
  left:0;
  position:absolute;
  top:.58em;
  width:10px;
}

.media{
  aspect-ratio:16/10;
  background:#0c1014;
  overflow:hidden;
  position:relative;
}

.media img{
  height:100%;
  object-fit:cover;
  transition:transform .35s ease;
  width:100%;
}

.media::after{
  background:linear-gradient(180deg, transparent, rgba(5,8,11,.72));
  content:"";
  height:45%;
  inset:auto 0 0 0;
  position:absolute;
}

.mobile-menu-toggle{
  background:rgba(142,220,255,.08);
  border:1px solid var(--line);
  border-radius:10px;
  color:var(--text);
  display:none;
  font-size:1.4rem;
  font-weight:800;
  height:42px;
  width:42px;
}

.nav{
  align-items:center;
  display:flex;
  flex-wrap:wrap;
  gap:18px;
  justify-content:center;
}

.nav a{
  color:#d6e5ee;
  font-weight:700;
  padding:10px 4px;
  position:relative;
}

.nav a.active::after,
.nav a:hover::after{
  background:var(--brand);
  bottom:3px;
  box-shadow:0 0 12px rgba(142,220,255,.85);
  content:"";
  height:2px;
  left:0;
  position:absolute;
  right:0;
}

.next{
  right:18px;
}

.panel{
  background:linear-gradient(180deg, rgba(11,15,18,.96), rgba(8,11,14,.98));
  border:1px solid var(--line);
  border-radius:22px;
  box-shadow:var(--shadow);
  padding:28px;
}

.prev{
  left:18px;
}

.price-range{
  background:rgba(142,220,255,0.08);
  border:1px solid rgba(142,220,255,0.18);
  border-radius:12px;
  color:#BFEFFF;
  font-weight:700;
  margin-top:18px;
  padding:12px 14px;
}

.section{
  padding:48px 0;
}

.section-title{
  margin-bottom:18px;
  text-align:center;
}

.section-title h2{
  font-size:clamp(2rem, 3.5vw, 3rem);
  margin:0 0 10px;
}

.section-title p{
  color:var(--muted);
  margin:0 auto;
  max-width:780px;
}

.site-footer{
  border-top:1px solid var(--line);
  color:#b2c1cc;
  margin-top:48px;
  padding:28px 0 40px;
}

.site-header{
  backdrop-filter:blur(12px);
  background:#000;
  border-bottom:1px solid var(--line);
  position:sticky;
  top:0;
  z-index:1000;
}

.small{
  color:#b4c3cf;
  font-size:.94rem;
}

.split{
  align-items:center;
  display:grid;
  gap:24px;
  grid-template-columns:1.04fr .96fr;
}

.stat{
  background:rgba(255,255,255,.01);
  border:1px solid rgba(142,220,255,.08);
  border-radius:18px;
  padding:24px 18px;
  text-align:center;
}

.stat span{
  color:var(--muted);
}

.stat strong{
  color:var(--brand);
  display:block;
  font-size:2rem;
}

.stats{
  display:grid;
  gap:16px;
  grid-template-columns:repeat(4, minmax(0, 1fr));
}

@media (max-width:700px){
  .about-page .section-title h2{
    font-size:1.9rem;
    line-height:1.15;
  }

  .brand img{
    width:190px;
  }

  .card{
    border-radius:16px;
  }

  .card-body{
    padding:22px;
  }

  .carousel-track img{
    height:420px;
  }

  .contact-cards,
  .form-grid,
  .gallery,
  .grid-2,
  .grid-3,
  .split,
  .stats{
    grid-template-columns:1fr;
  }

  .cta-banner{
    padding:28px 24px;
  }

  .cta-banner p{
    margin-bottom:14px;
  }

  .header-inner{
    display:grid;
    gap:6px;
    grid-template-columns:1fr auto;
    min-height:auto;
    padding:8px 0 10px;
  }

  .header-inner > .btn{
    border-radius:10px;
    font-size:.84rem;
    grid-column:1 / -1;
    justify-self:center;
    min-height:36px;
    padding:0 14px;
  }

  .hero{
    min-height:300px;
  }

  .hero h1{
    font-size:1.9rem;
    line-height:1.05;
    margin-inline:auto;
    max-width:360px;
  }

  .hero p{
    font-size:1rem;
  }

  .hero-actions{
    align-items:center;
    flex-direction:column;
    gap:12px;
  }

  .hero-actions .btn{
    max-width:260px;
    width:100%;
  }

  .hero-content{
    padding:24px 10px 30px;
    width:calc(100% - 28px);
  }

  .kicker{
    font-size:.75rem;
  }

  .mobile-menu-toggle{
    align-items:center;
    background:rgba(142,220,255,.08);
    border:1px solid var(--line);
    border-radius:10px;
    color:var(--text);
    display:inline-flex;
    font-size:1.4rem;
    font-weight:800;
    height:42px;
    justify-content:center;
    line-height:1;
    padding:0;
    width:42px;
  }

  .nav{
    display:none;
    flex-direction:column;
    gap:6px;
    grid-column:1 / -1;
    padding:10px 0 4px;
  }

  .panel{
    padding:22px;
  }

  .price-range{
    margin-top:14px;
    padding:10px 12px;
  }

  .section-title h2{
    font-size:2rem;
    line-height:1.15;
  }

  .site-header.menu-open .nav{
    display:flex;
  }
}
