
    :root{
      --bg:#f6fbff;
      --bg-soft:#edf8ff;
      --white:#ffffff;
      --text:#16324a;
      --muted:#64778b;
      --line:rgba(22,50,74,0.08);
      --blue:#dff2ff;
      --blue-strong:#9ed8ff;
      --mint:#def6ef;
      --yellow:#fff2b8;
      --peach:#ffe2d6;
      --coral:#ff7f73;
      --coral-dark:#ef695d;
      --navy:#16324a;
      --shadow:0 20px 60px rgba(34,77,117,0.10);
      --shadow-soft:0 12px 30px rgba(34,77,117,0.08);
      --radius-xl:34px;
      --radius-lg:28px;
      --radius-md:22px;
      --container:1240px;
    }

    *{box-sizing:border-box}
    html{scroll-behavior:smooth}
    body{
      margin:0;
      font-family:'DM Sans',sans-serif;
      color:var(--text);
      background:
        radial-gradient(circle at 0% 0%, rgba(255,242,184,0.45), transparent 24%),
        radial-gradient(circle at 100% 10%, rgba(223,242,255,0.85), transparent 28%),
        radial-gradient(circle at 80% 100%, rgba(222,246,239,0.55), transparent 20%),
        var(--bg);
      line-height:1.6;
    }

    body.menu-open{
      overflow:hidden;
    }

    img{max-width:100%;display:block}
    a{text-decoration:none;color:inherit}

    .container{
      width:min(var(--container), calc(100% - 32px));
      margin:0 auto;
    }

    .site-header{
      position:sticky;
      top:0;
      z-index:1000;
      padding:16px 0;
      background:rgba(246,251,255,0.82);
      backdrop-filter:blur(12px);
      border-bottom:1px solid rgba(255,255,255,0.35);
    }

    .header-row{
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap:20px;
    }

    .brand{
      display:flex;
      align-items:center;
      gap:14px;
      min-width:0;
      position:relative;
      z-index:1002;
    }

    .brand-badge{
      width:54px;
      height:54px;
      border-radius:18px;
      display:flex;
      align-items:center;
      justify-content:center;
      background:linear-gradient(135deg,var(--yellow),var(--peach),var(--blue));
      box-shadow:var(--shadow-soft);
      font-size:24px;
      flex:0 0 auto;
    }

    .brand-title{
      margin:0;
      font-family:'Fraunces',serif;
      font-size:1.55rem;
      line-height:1.1;
      color:var(--navy);
      letter-spacing:-0.02em;
    }

    .desktop-nav{
      display:flex;
      align-items:center;
      gap:8px;
      flex-wrap:wrap;
    }

    .desktop-nav a{
      padding:12px 16px;
      border-radius:999px;
      font-size:.95rem;
      font-weight:700;
      color:var(--navy);
    }

    .desktop-nav a:hover{
      background:rgba(255,255,255,0.82);
    }

    .btn{
      display:inline-flex;
      align-items:center;
      justify-content:center;
      gap:10px;
      padding:15px 24px;
      border:none;
      border-radius:999px;
      cursor:pointer;
      font:inherit;
      font-weight:800;
      transition:.25s ease;
    }

    .btn-primary{
      color:#fff;
      background:linear-gradient(135deg,var(--coral),#ff9a78);
      box-shadow:0 16px 36px rgba(255,127,115,0.26);
    }

    .btn-primary:hover{
      transform:translateY(-2px);
      background:linear-gradient(135deg,var(--coral-dark),#ff8a67);
    }

    .btn-light{
      color:var(--navy);
      background:rgba(255,255,255,0.92);
      border:1px solid var(--line);
      box-shadow:var(--shadow-soft);
    }

    .btn-light:hover{
      transform:translateY(-2px);
      background:#fff;
    }

    .menu-toggle{
      display:none;
      width:52px;
      height:52px;
      border:none;
      border-radius:18px;
      background:#fff;
      box-shadow:var(--shadow-soft);
      align-items:center;
      justify-content:center;
      flex-direction:column;
      gap:5px;
      cursor:pointer;
      position:relative;
      z-index:1002;
    }

    .menu-toggle span{
      width:22px;
      height:2px;
      border-radius:999px;
      background:var(--navy);
      transition:.25s ease;
    }

    .menu-toggle.active span:nth-child(1){
      transform:translateY(7px) rotate(45deg);
    }

    .menu-toggle.active span:nth-child(2){
      opacity:0;
    }

    .menu-toggle.active span:nth-child(3){
      transform:translateY(-7px) rotate(-45deg);
    }

    .mobile-menu{
      position:fixed;
      inset:0;
      z-index:1001;
      background:rgba(246,251,255,0.98);
      backdrop-filter:blur(10px);
      opacity:0;
      pointer-events:none;
      transition:.25s ease;
    }

    .mobile-menu.open{
      opacity:1;
      pointer-events:auto;
    }

    .mobile-menu-inner{
      padding:110px 20px 30px;
      display:flex;
      flex-direction:column;
      gap:14px;
    }

    .mobile-menu a{
      padding:18px 20px;
      border-radius:22px;
      background:#fff;
      box-shadow:var(--shadow-soft);
      font-weight:800;
      font-size:1.05rem;
      color:var(--navy);
    }

    .mobile-menu .mobile-cta-link{
      background:linear-gradient(135deg,var(--coral),#ff9a78);
      color:#fff;
    }

    .hero{
      padding:56px 0 74px;
    }

    .hero-wrap{
      display:grid;
      grid-template-columns:1.02fr .98fr;
      gap:34px;
      align-items:center;
    }

    .hero-left{
      position:relative;
      z-index:1;
    }

    .eyebrow{
      display:inline-flex;
      align-items:center;
      gap:10px;
      padding:10px 16px;
      border-radius:999px;
      background:#fff;
      border:1px solid var(--line);
      box-shadow:var(--shadow-soft);
      font-size:.92rem;
      font-weight:800;
      color:var(--navy);
      margin-bottom:18px;
    }

    .hero h1,
    .section-head h2,
    .service-box h3,
    .price-card h3,
    .faq-item h3,
    .step h3,
    .feature-card h3,
    .quote strong,
    .contact-panel h2{
      font-family:'Fraunces',serif;
    }

    .hero h1{
      margin:0 0 18px;
      font-size:clamp(2.8rem,4vw,5.2rem);
      line-height:.96;
      letter-spacing:-0.045em;
      max-width:680px;
      font-weight:700;
    }

    .hero h1 .accent{
      color:var(--coral);
    }

    .hero-lead{
      margin:0 0 28px;
      max-width:620px;
      color:var(--muted);
      font-size:1.08rem;
    }

    .hero-actions{
      display:flex;
      flex-wrap:wrap;
      gap:14px;
      margin-bottom:24px;
    }

    .hero-meta{
      display:flex;
      flex-wrap:wrap;
      gap:12px;
    }

    .hero-meta-item{
      display:inline-flex;
      align-items:center;
      gap:10px;
      padding:12px 16px;
      border-radius:999px;
      background:rgba(255,255,255,0.92);
      border:1px solid var(--line);
      box-shadow:var(--shadow-soft);
      font-size:.95rem;
      font-weight:700;
      color:var(--navy);
    }

    .hero-right{
      position:relative;
    }

    .hero-visual{
      position:relative;
      min-height:620px;
    }

    .hero-bg-shape{
      position:absolute;
      inset:34px 24px 0 28px;
      border-radius:38px;
      background:linear-gradient(135deg, rgba(223,242,255,0.95), rgba(255,242,184,0.58), rgba(255,226,214,0.56));
    }

    .hero-photo{
      position:absolute;
      inset:0 0 38px 42px;
      border-radius:36px;
      overflow:hidden;
      border:10px solid rgba(255,255,255);
      box-shadow:var(--shadow);
      background:
        linear-gradient(180deg, rgba(23,50,74,0.04), rgba(23,50,74,0.10)),
        url('https://lastepeopildid.ee/images/pilt1.jpg') center/cover no-repeat;
    }

    .hero-card{
      position:absolute;
      left:0;
      bottom:0;
      width:270px;
      padding:18px 18px;
      border-radius:26px;
      background:#fff;
      box-shadow:0 18px 40px rgba(34,77,117,0.12);
    }

    .hero-card strong{
      display:block;
      margin-bottom:6px;
      color:var(--navy);
      font-size:1.08rem;
      font-family:'Fraunces',serif;
    }

    .hero-card span{
      color:var(--muted);
      font-size:.95rem;
    }

    section{
      padding:92px 0;
    }

    .section-head{
      max-width:760px;
      margin:0 auto 42px;
      text-align:center;
    }

    .section-head.left{
      max-width:680px;
      margin:0 0 34px;
      text-align:left;
    }

    .section-kicker{
      display:inline-block;
      margin-bottom:12px;
      padding:8px 14px;
      border-radius:999px;
      background:rgba(255,255,255,0.88);
      border:1px solid var(--line);
      font-size:.9rem;
      font-weight:800;
      color:var(--navy);
    }

    .section-head h2{
      margin:0 0 12px;
      font-size:clamp(2rem,3vw,3.2rem);
      line-height:1.05;
      letter-spacing:-0.03em;
      font-weight:700;
    }

    .section-head p{
      margin:0;
      color:var(--muted);
      font-size:1.05rem;
    }

    .grid-3{
      display:grid;
      grid-template-columns:repeat(3,1fr);
      gap:24px;
    }

    .card{
      background:rgba(255,255,255,0.90);
      border:1px solid rgba(255,255,255,0.88);
      border-radius:30px;
      padding:28px;
      box-shadow:var(--shadow);
    }



.privacy-box{
  display:grid;
  grid-template-columns:90px 1fr;
  gap:24px;
  align-items:start;
  padding:34px;
  border-radius:34px;
  background:rgba(255,255,255,0.93);
  box-shadow:var(--shadow);
  margin:0 auto;
}

.privacy-icon{
  width:90px;
  height:90px;
  border-radius:28px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:2rem;
  background:linear-gradient(135deg,var(--blue),var(--mint));
  box-shadow:var(--shadow-soft);
}

.privacy-content h2{
  margin:0 0 12px;
  font-size:clamp(1.9rem, 3vw, 2.7rem);
  line-height:1.08;
  letter-spacing:-0.03em;
  font-weight:700;
  font-family:'Fraunces',serif;
  color:var(--navy);
}

.privacy-content p{
  margin:0 0 14px;
  color:var(--muted);
  font-size:1.02rem;
}

.privacy-content p:last-child{
  margin-bottom:0;
}

@media (max-width:700px){
  .privacy-box{
    grid-template-columns:1fr;
    padding:26px 20px;
  }

  .privacy-icon{
    width:74px;
    height:74px;
    border-radius:22px;
    font-size:1.7rem;
  }
}

    .feature-card{
      position:relative;
      overflow:hidden;
    }

    .feature-card:before{
      content:"";
      position:absolute;
      width:110px;
      height:110px;
      right:-24px;
      top:-24px;
      border-radius:26px;
      background:linear-gradient(135deg, rgba(223,242,255), rgba(255,242,184));
    }

    .icon-chip{
      position:relative;
      z-index:1;
      width:64px;
      height:64px;
      margin-bottom:16px;
      border-radius:22px;
      display:flex;
      align-items:center;
      justify-content:center;
      background:linear-gradient(135deg,var(--blue),var(--mint));
      font-size:28px;
    }

    .feature-card h3{
      position:relative;
      z-index:1;
      margin:0 0 10px;
      font-size:1.24rem;
      font-weight:700;
    }

    .feature-card p{
      position:relative;
      z-index:1;
      margin:0;
      color:var(--muted);
    }

    .service-layout{
      display:grid;
      grid-template-columns:1fr .92fr;
      gap:28px;
      align-items:start;
    }

    .service-copy .list{
      display:grid;
      gap:14px;
      margin-top:22px;
    }

    .list-item{
      display:flex;
      gap:14px;
      align-items:flex-start;
      padding:16px 18px;
      border-radius:22px;
      background:rgba(255,255,255,0.80);
      border:1px solid rgba(23,50,74,0.06);
    }

    .list-item .dot{
      width:34px;
      height:34px;
      border-radius:12px;
      display:flex;
      align-items:center;
      justify-content:center;
      background:linear-gradient(135deg,var(--yellow),var(--peach));
      font-weight:800;
      flex:0 0 auto;
    }

    .service-box{
      padding:30px;
      border-radius:34px;
      background:linear-gradient(180deg, rgba(255,255,255), rgba(255,255,255));
      box-shadow:var(--shadow);
      border:1px solid rgba(255,255,255,0.88);
    }

    .service-box h3{
      margin:0 0 16px;
      font-size:1.38rem;
      font-weight:700;
    }

    .pill-list{
      display:flex;
      flex-wrap:wrap;
      gap:10px;
    }

    .pill{
      padding:10px 14px;
      border-radius:999px;
      background:#fff;
      border:1px solid rgba(23,50,74,0.08);
      font-weight:700;
      color:var(--navy);
      font-size:.94rem;
    }

    .about-wrap{
      display:grid;
      grid-template-columns:.95fr 1.05fr;
      gap:28px;
      align-items:center;
    }

    .about-photo{
      min-height:520px;
      border-radius:34px;
      box-shadow:var(--shadow);
      background:
        linear-gradient(180deg, rgba(23,50,74,0.03), rgba(23,50,74,0.08)),
        url('https://lastepeopildid.ee/images/rait3.jpg') center/cover no-repeat;
      border:10px solid rgba(255,255,255);
    }

    .about-card{
      padding:34px;
      border-radius:34px;
      background:rgba(255,255,255,0.93);
      box-shadow:var(--shadow);
    }

    .about-card h2{
      margin:0 0 16px;
      font-size:clamp(2rem,3vw,3rem);
      line-height:1.05;
      letter-spacing:-0.03em;
      font-weight:700;
      font-family:'Fraunces',serif;
    }

    .about-card p{
      margin:0 0 16px;
      color:var(--muted);
      font-size:1.02rem;
    }

    .about-sign{
      margin-top:18px;
      font-weight:800;
      color:var(--navy);
    }

    .pricing-grid{
      display:grid;
      grid-template-columns:repeat(3,1fr);
      gap:24px;
      align-items:stretch;
    }

    .price-card{
      padding:30px;
      border-radius:32px;
      background:rgba(255,255,255,0.93);
      box-shadow:var(--shadow);
      border:1px solid rgba(255,255,255,0.90);
    }

    .price-card.featured{
      transform:translateY(-8px);
      border:2px solid rgba(255,127,115,0.22);
      background:linear-gradient(180deg, #ffffff, #fff8f4);
    }

    .price-badge{
      display:inline-block;
      margin-bottom:14px;
      padding:8px 12px;
      border-radius:999px;
      background:var(--peach);
      color:var(--coral-dark);
      font-size:.82rem;
      font-weight:800;
    }

    .price-card h3{
      margin:0 0 6px;
      font-size:1.5rem;
      font-weight:700;
    }

    .price-sub{
      margin-bottom:18px;
      color:var(--muted);
    }

    .price-value{
      margin-bottom:18px;
      font-size:3rem;
      line-height:1;
      letter-spacing:-0.04em;
      font-weight:800;
      color:var(--navy);
    }

    .price-value small{
      color:var(--muted);
      font-weight:700;
    }

    .price-list{
      list-style:none;
      padding:0;
      margin:0 0 24px;
      display:grid;
      gap:12px;
    }

    .price-list li{
      display:flex;
      gap:12px;
      align-items:flex-start;
    }

    .check{
      width:24px;
      height:24px;
      border-radius:999px;
      display:flex;
      align-items:center;
      justify-content:center;
      background:linear-gradient(135deg,var(--blue),var(--mint));
      flex:0 0 auto;
      font-size:.86rem;
      margin-top:1px;
    }

    .gallery-grid{
      display:grid;
      grid-template-columns:1.1fr .9fr .9fr;
      grid-template-rows:250px 250px;
      gap:22px;
    }

    .gallery-item{
      position:relative;
      border-radius:28px;
      overflow:hidden;
      min-height:220px;
      box-shadow:var(--shadow);
    }

    .gallery-item:before{
      content:"";
      position:absolute;
      inset:0;
      background:linear-gradient(180deg, transparent 42%, rgba(11,30,49,0.58));
      z-index:1;
    }

    .gallery-item .label{
      position:absolute;
      left:20px;
      bottom:18px;
      z-index:2;
      color:#fff;
      font-weight:800;
      font-size:1.05rem;
    }



.gallery-grid-new{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:22px;
}

.gallery-card{
  position:relative;
  display:block;
  overflow:hidden;
  border-radius:28px;
  box-shadow:var(--shadow);
  min-height:280px;
  background:#ddd;
}

.gallery-card img{
  width:100%;
  height:100%;
  min-height:280px;
  object-fit:cover;
  display:block;
  transition:transform .45s ease;
}

.gallery-card:hover img{
  transform:scale(1.04);
}

.gallery-overlay{
  position:absolute;
  inset:0;
  display:flex;
  align-items:flex-end;
  padding:20px;
  background:linear-gradient(180deg, rgba(0,0,0,0.02) 35%, rgba(11,30,49,0.62) 100%);
}

.gallery-label{
  color:#fff;
  font-weight:800;
  font-size:1.02rem;
  line-height:1.35;
}

.gallery-lightbox{
  position:fixed;
  inset:0;
  background:rgba(10,16,24,0.92);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:30px;
  z-index:3000;
  opacity:0;
  pointer-events:none;
  transition:opacity .25s ease;
}

.gallery-lightbox.open{
  opacity:1;
  pointer-events:auto;
}

.gallery-lightbox-inner{
  position:relative;
  width:min(1100px, 100%);
  max-height:100%;
  display:flex;
  flex-direction:column;
  align-items:center;
}

.gallery-lightbox-image-wrap{
  position:relative;
  width:100%;
  display:flex;
  align-items:center;
  justify-content:center;
}

.gallery-lightbox img{
  max-width:100%;
  max-height:80vh;
  border-radius:22px;
  box-shadow:0 20px 60px rgba(0,0,0,0.35);
}

.gallery-lightbox-caption{
  margin-top:18px;
  color:#fff;
  font-size:1rem;
  text-align:center;
  max-width:760px;
}

.gallery-close,
.gallery-prev,
.gallery-next{
  position:absolute;
  border:none;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#fff;
  background:rgba(255,255,255,0.14);
  backdrop-filter:blur(8px);
  transition:.2s ease;
}

.gallery-close:hover,
.gallery-prev:hover,
.gallery-next:hover{
  background:rgba(255,255,255,0.22);
}

.gallery-close{
  top:-12px;
  right:-12px;
  width:48px;
  height:48px;
  border-radius:50%;
  font-size:1.4rem;
  z-index:2;
}

.gallery-prev,
.gallery-next{
  top:50%;
  transform:translateY(-50%);
  width:56px;
  height:56px;
  border-radius:50%;
  font-size:1.5rem;
}

.gallery-prev{
  left:-72px;
}

.gallery-next{
  right:-72px;
}

@media (max-width:1100px){
  .gallery-grid-new{
    grid-template-columns:repeat(2, 1fr);
  }

  .gallery-prev{
    left:10px;
  }

  .gallery-next{
    right:10px;
  }

  .gallery-lightbox-image-wrap{
    padding:0 60px;
  }
}

@media (max-width:700px){
  .gallery-grid-new{
    grid-template-columns:1fr;
  }

  .gallery-card,
  .gallery-card img{
    min-height:240px;
  }

  .gallery-lightbox{
    padding:16px;
  }

  .gallery-lightbox-image-wrap{
    padding:0 46px;
  }

  .gallery-prev,
  .gallery-next{
    width:44px;
    height:44px;
    font-size:1.2rem;
  }

  .gallery-close{
    width:42px;
    height:42px;
    top:-8px;
    right:-4px;
  }

  .gallery-lightbox-caption{
    font-size:.95rem;
    margin-top:14px;
  }
}


    .steps-grid{
      display:grid;
      grid-template-columns:repeat(4,1fr);
      gap:22px;
    }

    .step{
      padding:28px;
      border-radius:28px;
      background:rgba(255,255,255,0.90);
      box-shadow:var(--shadow);
    }

    .step-num{
      width:54px;
      height:54px;
      margin-bottom:18px;
      border-radius:18px;
      display:flex;
      align-items:center;
      justify-content:center;
      background:linear-gradient(135deg,var(--yellow),var(--peach));
      font-weight:800;
      font-size:1.15rem;
    }

    .step h3{
      margin:0 0 8px;
      font-size:1.18rem;
      font-weight:700;
    }

    .step p{
      margin:0;
      color:var(--muted);
    }

    .testimonials{
      display:grid;
      grid-template-columns:repeat(3,1fr);
      gap:24px;
    }

    .quote{
      padding:30px;
      border-radius:30px;
      background:rgba(255,255,255,0.93);
      box-shadow:var(--shadow);
    }

    .quote-mark{
      font-family:'Fraunces',serif;
      font-size:3.6rem;
      line-height:1;
      color:var(--blue-strong);
      margin-bottom:8px;
    }

    .quote p{
      margin:0 0 18px;
      font-size:1.05rem;
    }

    .quote strong{
      display:block;
      color:var(--navy);
      font-weight:700;
    }


    .btn-messenger{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:12px 22px;
  border-radius:999px;
  font-weight:600;
  text-decoration:none;
  color:#fff;
  background:linear-gradient(135deg,#0084ff,#32a8ff);
  box-shadow:0 16px 36px rgba(0,132,255,0.28);
  transition:.25s ease;
}

.btn-messenger:hover{
  transform:translateY(-2px);
  background:linear-gradient(135deg,#0074e6,#1e9bff);
}

    .faq-wrap{
      display:grid;
      grid-template-columns:1fr 1fr;
      gap:18px;
    }

    .faq-item{
      padding:24px;
      border-radius:26px;
      background:rgba(255,255,255,0.92);
      box-shadow:var(--shadow);
    }

    .faq-item h3{
      margin:0 0 10px;
      font-size:1.12rem;
      font-weight:700;
    }

    .faq-item p{
      margin:0;
      color:var(--muted);
    }

    .contact-simple{
      margin:0 auto;
      padding:40px;
      border-radius:34px;
      background:rgba(255,255,255,0.93);
      box-shadow:var(--shadow);
      text-align:center;
    }

    .contact-simple h2{
      margin:0 0 14px;
      font-size:clamp(2rem,3vw,3rem);
      line-height:1.05;
      letter-spacing:-0.03em;
      font-weight:700;
      font-family:'Fraunces',serif;
    }

    .contact-simple p{
      margin:0 0 24px;
      color:var(--muted);
      font-size:1.04rem;
    }

    .contact-links{
      display:flex;
      flex-wrap:wrap;
      justify-content:center;
      gap:14px;
      margin-top:10px;
    }

    .contact-link{
      display:inline-flex;
      align-items:center;
      justify-content:center;
      gap:10px;
      padding:14px 18px;
      border-radius:999px;
      background:#fff;
      border:1px solid rgba(22,50,74,0.08);
      box-shadow:var(--shadow-soft);
      font-weight:700;
      color:var(--navy);
    }

    .footer{
      padding:34px 0 50px;
    }

    .footer-box{
      padding:30px;
      border-radius:34px;
      background:rgba(255,255,255,0.88);
      box-shadow:var(--shadow);
    }

    .footer-grid{
      display:grid;
      grid-template-columns:1.2fr .8fr .8fr .8fr;
      gap:24px;
    }

    .footer h4,.footer h5{
      margin:0 0 14px;
      font-family:'Fraunces',serif;
      font-weight:700;
    }

    .footer p,.footer li,.footer a{
      color:var(--muted);
      font-size:.97rem;
    }

    .footer ul{
      list-style:none;
      padding:0;
      margin:0;
      display:grid;
      gap:10px;
    }

    .footer-bottom{
      margin-top:24px;
      padding-top:18px;
      border-top:1px solid rgba(23,50,74,0.08);
      text-align:center;
      color:var(--muted);
      font-size:.94rem;
    }

    .mobile-cta{
      position:fixed;
      left:14px;
      right:14px;
      bottom:14px;
      z-index:999;
      display:none;
    }

    @media (max-width:1100px){
      .hero-wrap,
      .service-layout,
      .about-wrap,
      .pricing-grid,
      .testimonials,
      .grid-3,
      .steps-grid,
      .footer-grid{
        grid-template-columns:1fr 1fr;
      }

      .gallery-grid{
        grid-template-columns:1fr 1fr;
        grid-template-rows:260px 260px 260px;
      }

      .g1{
        grid-row:auto;
      }

      .hero-wrap{
        grid-template-columns:1fr;
      }

      .hero-visual{
        min-height:520px;
        max-width:720px;
        margin:0 auto;
      }
    }

    @media (max-width:860px){
      .desktop-nav{
        display:none;
      }

      .menu-toggle{
        display:flex;
      }

      .service-layout,
      .about-wrap,
      .pricing-grid,
      .testimonials,
      .grid-3,
      .steps-grid,
      .faq-wrap,
      .footer-grid{
        grid-template-columns:1fr;
      }

      .hero{
        padding:34px 0 56px;
      }

      .hero h1{
        font-size:2.4rem;
      }

      .hero-lead{
        font-size:1rem;
      }

      .hero-visual{
        min-height:390px;
      }

      .hero-bg-shape{
        inset:22px 16px 0 16px;
      }

      .hero-photo{
        inset:0 0 24px 18px;
        border-radius:28px;
      }

      .hero-card{
        position:relative;
        left:auto;
        bottom:auto;
        width:100%;
        margin-top:16px;
      }

      .about-photo{
        min-height:360px;
      }

      .gallery-grid{
        grid-template-columns:1fr;
        grid-template-rows:auto;
      }

      .gallery-item{
        min-height:250px;
      }

      .mobile-cta{
        display:block;
      }

      body{
        padding-bottom:84px;
      }
    }

    @media (max-width:560px){
      .container{
        width:min(var(--container), calc(100% - 20px));
      }

      .site-header{
        padding:14px 0;
      }

      .brand-badge{
        width:46px;
        height:46px;
        border-radius:16px;
        font-size:21px;
      }

      .brand-title{
        font-size:1.2rem;
      }

      .hero h1{
        font-size:2.05rem;
      }

      .eyebrow{
        font-size:.84rem;
        padding:9px 13px;
      }

      .hero-meta{
        flex-direction:column;
        align-items:flex-start;
      }

      .hero-meta-item{
        width:100%;
        justify-content:flex-start;
      }

      .mobile-menu-inner{
        padding:100px 16px 24px;
      }

      .mobile-menu a{
        padding:16px 18px;
        font-size:1rem;
      }

      .contact-simple{
        padding:28px 20px;
      }
    }
