/* ===== Ndeshi & Jakes — Brand stylesheet ===== */
:root{
  --navy:#0e1119;
  --navy-soft:#161b27;
  --gold:#c2a161;
  --gold-deep:#a8893f;
  --ink:#1c2230;
  --muted:#6b7280;
  --line:#e7e3da;
  --cream:#f7f5f0;
  --white:#ffffff;
  --maxw:1180px;
  --shadow:0 18px 50px -22px rgba(14,17,25,.35);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Jost',system-ui,sans-serif;
  color:var(--ink);
  background:var(--white);
  line-height:1.65;
  font-weight:300;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:'Cormorant Garamond',Georgia,serif;font-weight:600;line-height:1.12;letter-spacing:.2px}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px}
.gold{color:var(--gold)}
.section{padding:54px 0}

/* ===== Buttons ===== */
.btn{
  display:inline-block;
  padding:14px 30px;
  font-size:.82rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  font-weight:500;
  border-radius:50px;
  transition:.25s ease;
  cursor:pointer;
  border:1px solid transparent;
}
.btn-gold{background:var(--gold);color:var(--navy)}
.btn-gold:hover{background:var(--gold-deep);transform:translateY(-2px)}
.btn-ghost{border-color:rgba(255,255,255,.5);color:#fff}
.btn-ghost:hover{background:rgba(255,255,255,.12);border-color:#fff}
.btn-block{width:100%;border:none}

/* ===== Header ===== */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:50;
  background:linear-gradient(100deg,var(--gold) 0%,#cdae71 45%,var(--gold-deep) 100%);
  transition:box-shadow .3s ease,padding .3s ease;
  padding:0;
  box-shadow:0 4px 22px -12px rgba(14,17,25,.5);
}
.header-inner{display:flex;align-items:stretch;justify-content:space-between;min-height:96px;transition:min-height .3s ease}
.site-header.scrolled .header-inner{min-height:74px}

/* white ribbon holding the logo */
.brand{
  display:flex;align-items:center;justify-content:center;
  background:#fff;padding:0 40px;margin-bottom:-18px;
  box-shadow:0 10px 26px -12px rgba(14,17,25,.45);
}
.brand-logo{height:74px;width:auto;transition:height .3s ease}
.site-header.scrolled .brand-logo{height:58px}

.nav{display:flex;align-items:center;gap:44px}
.nav a{
  color:var(--navy);font-size:1.05rem;letter-spacing:.14em;text-transform:uppercase;
  font-weight:500;position:relative;padding:6px 0;
}
.nav a:not(.nav-cta)::after{
  content:"";position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--navy);transition:width .25s ease;
}
.nav a:not(.nav-cta):hover::after{width:100%}
.nav a.nav-cta{background:var(--navy);color:#fff;border:2px solid var(--navy);padding:10px 28px;border-radius:50px;font-weight:500;transition:.25s ease}
.nav a.nav-cta:hover{background:transparent;color:var(--navy)}

.nav-toggle{display:none;background:none;border:0;flex-direction:column;gap:5px;cursor:pointer;padding:6px;align-self:center}
.nav-toggle span{display:block;width:28px;height:3px;background:var(--navy);transition:.3s}

/* ===== Hero ===== */
.hero{position:relative;min-height:64vh;display:flex;align-items:center;color:#fff;overflow:hidden}
.hero-slides{position:absolute;inset:0}
.hero-bg{
  position:absolute;inset:0;background-size:cover;background-position:center;
  opacity:0;transform:scale(1.08);
  transition:opacity 1.4s ease, transform 7s ease;
}
.hero-bg.active{opacity:1;transform:scale(1)}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(105deg,rgba(14,17,25,.92) 0%,rgba(14,17,25,.72) 45%,rgba(14,17,25,.35) 100%)}
.hero-content{position:relative;z-index:2;max-width:760px;padding-top:70px}
.eyebrow{
  color:var(--gold);letter-spacing:.32em;text-transform:uppercase;font-size:.78rem;
  margin-bottom:22px;font-weight:500;
}
.hero h1{font-size:clamp(2.4rem,5.5vw,4.2rem);margin-bottom:28px}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap}

/* hero carousel controls */
.hero-arrow{
  position:absolute;top:50%;transform:translateY(-50%);z-index:3;
  width:54px;height:54px;border:1px solid rgba(255,255,255,.45);border-radius:50%;cursor:pointer;
  background:rgba(14,17,25,.25);color:#fff;font-size:1.7rem;line-height:1;
  display:flex;align-items:center;justify-content:center;transition:.25s;
}
.hero-arrow:hover{background:var(--gold);border-color:var(--gold);color:var(--navy)}
.hero-arrow.prev{left:26px}
.hero-arrow.next{right:26px}
.hero-dots{position:absolute;bottom:34px;left:0;right:0;display:flex;justify-content:center;gap:12px;z-index:3}
.hero-dots button{
  width:12px;height:12px;border-radius:50%;border:0;cursor:pointer;padding:0;
  background:rgba(255,255,255,.45);transition:.25s;
}
.hero-dots button.active{background:var(--gold);transform:scale(1.25)}

/* ===== Stats ===== */
.stats{background:var(--navy);color:#fff}
.stats-grid{display:flex;justify-content:center;gap:0;flex-wrap:wrap}
.stat{flex:1;min-width:200px;text-align:center;padding:26px 20px;border-right:1px solid rgba(255,255,255,.08)}
.stat:last-child{border-right:0}
.stat-num{display:block;font-family:'Cormorant Garamond',serif;font-size:3.2rem;font-weight:700;color:var(--gold);line-height:1}
.stat-num .plus{font-size:2rem}
.stat-label{font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.7)}

/* ===== Section headings ===== */
.section-eyebrow{color:var(--gold-deep);letter-spacing:.28em;text-transform:uppercase;font-size:.76rem;font-weight:600;margin-bottom:14px}
.section-head h2,.about-text h2,.contact-intro h2{font-size:clamp(2rem,4vw,2.9rem);margin-bottom:18px;color:var(--navy)}
.section-head{margin-bottom:38px}
.section-head.center{text-align:center;max-width:680px;margin-left:auto;margin-right:auto}
.section-sub{color:var(--muted);font-size:1.08rem}

/* ===== About ===== */
.about{background:var(--cream)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.about-media{position:relative}
.about-media img{border-radius:22px;box-shadow:var(--shadow);width:100%;object-fit:cover;aspect-ratio:4/3}
.about-badge{
  position:absolute;bottom:-26px;left:-26px;background:var(--gold);color:var(--navy);
  font-family:'Cormorant Garamond',serif;text-align:center;padding:20px 26px;border-radius:18px;
  line-height:1.1;font-size:.9rem;letter-spacing:.1em;box-shadow:var(--shadow);
}
.about-badge strong{font-size:1.9rem;display:block}
.about-text p{color:#3a4150;margin-bottom:16px}
.values{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:12px 20px;margin-top:28px}
.values li{display:flex;align-items:center;gap:12px;font-weight:400;color:var(--navy)}
.values li::before{content:"";width:8px;height:8px;background:var(--gold);transform:rotate(45deg);flex:none}

/* ===== Services grid ===== */
.services{background:var(--white)}
.services-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
.service-card{
  background:var(--white);border:1px solid var(--line);border-radius:22px;overflow:hidden;
  box-shadow:0 10px 30px -24px rgba(14,17,25,.4);transition:.3s ease;
  display:flex;flex-direction:column;
}
.service-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--gold)}
.service-img{position:relative;height:200px;background-size:cover;background-position:center;overflow:hidden}
.service-img::before{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(14,17,25,.55),rgba(14,17,25,0) 60%);transition:opacity .3s ease}
.service-card:hover .service-img::before{opacity:.7}
.service-icon{
  position:absolute;left:26px;bottom:-26px;z-index:2;
  width:56px;height:56px;border-radius:50%;
  background:var(--gold);color:var(--navy);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 10px 22px -6px rgba(14,17,25,.55);
  transition:transform .35s cubic-bezier(.34,1.56,.64,1),background .3s ease;
}
.service-card:hover .service-icon{transform:translateY(-5px) rotate(-8deg);background:#d8bd80}
.service-body{padding:42px 30px 30px;display:flex;flex-direction:column;flex:1}
.service-body h3{font-size:1.55rem;margin-bottom:12px;color:var(--navy);position:relative;padding-bottom:12px}
.service-body h3::after{content:"";position:absolute;left:0;bottom:0;width:44px;height:2px;background:var(--gold);transition:width .3s ease}
.service-card:hover .service-body h3::after{width:72px}
.service-body p{color:#4b5160;font-size:.98rem;flex:1}

/* ===== Feature band ===== */
.feature{position:relative;padding:68px 0;color:#fff;text-align:center;overflow:hidden}
.feature-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.feature-overlay{position:absolute;inset:0;background:rgba(14,17,25,.82)}
.feature-content{position:relative;z-index:2;max-width:680px}
.feature-content h2{font-size:clamp(2rem,4vw,3rem);margin-bottom:18px}
.feature-content p{color:rgba(255,255,255,.85);font-size:1.12rem;margin-bottom:32px}

/* ===== Contact ===== */
.contact{background:var(--cream)}
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:64px;align-items:start}
.contact-intro p{color:#3a4150;margin-bottom:30px}
.contact-list{list-style:none;display:flex;flex-direction:column;gap:20px}
.contact-list li{display:flex;flex-direction:column;gap:3px;border-left:2px solid var(--gold);padding-left:18px}
.ci-label{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-deep);font-weight:600}
.contact-list a,.contact-list span:not(.ci-label){font-size:1.1rem;color:var(--navy)}
.contact-list a:hover{color:var(--gold-deep)}

.contact-form{background:#fff;padding:40px;border-radius:24px;box-shadow:var(--shadow)}
.field{margin-bottom:20px}
.field label{display:block;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:8px;font-weight:500}
.field input,.field select,.field textarea{
  width:100%;padding:13px 16px;border:1px solid var(--line);border-radius:14px;
  font-family:inherit;font-size:1rem;color:var(--ink);background:#fcfbf8;transition:.2s;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold);background:#fff}
.field textarea{resize:vertical}
.form-note{margin-top:16px;color:var(--gold-deep);font-weight:400;text-align:center}
.form-alert{padding:12px 18px;border-radius:14px;margin-bottom:20px;font-size:.95rem}
.form-alert.success{background:#e8f4ea;border:1px solid #bfe3c6;color:#256b36}
.form-alert.error{background:#fbe9e9;border:1px solid #f1c9c4;color:#a3271c}

/* ===== Footer ===== */
.site-footer{background:var(--navy);color:rgba(255,255,255,.75)}
.footer-inner{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:48px;padding:52px 24px 38px;align-items:start}
.footer-col h4{font-family:'Jost',sans-serif;font-size:.82rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:18px;font-weight:600}
.footer-brand img{height:62px;filter:brightness(0) invert(1);margin-bottom:16px}
.footer-brand p{max-width:360px;font-size:.95rem;line-height:1.7}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:11px}
.footer-links a{font-size:.94rem;color:rgba(255,255,255,.72);transition:.2s}
.footer-links a:hover{color:var(--gold);padding-left:4px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1)}
.footer-bottom-inner{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;padding:20px 24px;font-size:.84rem;color:rgba(255,255,255,.5)}
.footer-socials{display:flex;gap:12px;margin-top:18px}
.footer-socials a{
  width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.1);color:#fff;transition:.25s ease;
}
.footer-socials a:hover{background:var(--gold);color:var(--navy);transform:translateY(-3px)}

.footer-credit{color:#fff}
.footer-credit a{color:#fff;font-weight:500}
.footer-credit a:hover{color:#fff;text-decoration:underline}
.footer-credit .heart{color:#fff}

/* Floating WhatsApp button */
.wa-float{
  position:fixed;right:22px;bottom:22px;z-index:60;
  width:56px;height:56px;border-radius:50%;
  background:#25d366;color:#fff;display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 22px -6px rgba(37,211,102,.7);transition:transform .2s ease,box-shadow .2s ease;
}
.wa-float:hover{transform:scale(1.08);box-shadow:0 10px 26px -6px rgba(37,211,102,.85)}
@media (max-width:520px){.wa-float{right:16px;bottom:16px;width:50px;height:50px}}
@media (max-width:760px){
  .footer-inner{grid-template-columns:1fr 1fr;gap:30px 24px}
  .footer-brand{grid-column:1 / -1}
  .footer-bottom-inner{justify-content:center;text-align:center}
}
@media (max-width:460px){
  .footer-inner{grid-template-columns:1fr}
}

/* ===== Responsive ===== */
@media (max-width:900px){
  .nav{
    position:fixed;inset:0 0 auto 0;top:0;flex-direction:column;justify-content:center;
    background:rgba(14,17,25,.99);height:100vh;transform:translateX(100%);transition:.35s ease;gap:30px;
  }
  .brand{position:relative;z-index:60}
  .nav.open{transform:translateX(0)}
  .nav a{font-size:1.1rem;color:#fff}
  .nav a.nav-cta{background:var(--gold);color:var(--navy);border-color:var(--gold);padding:12px 34px}
  .nav a.nav-cta:hover{background:transparent;color:#fff}
  .nav-toggle{display:flex;z-index:60}
  .nav-toggle.open span{background:#fff}
  .nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav-toggle.open span:nth-child(2){opacity:0}
  .nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .about-grid,.contact-grid{grid-template-columns:1fr;gap:48px}
  .services-grid{grid-template-columns:1fr}
  .about-badge{left:auto;right:16px;bottom:-20px}
  .hero-arrow{width:42px;height:42px;font-size:1.3rem}
  .hero-arrow.prev{left:12px}
  .hero-arrow.next{right:12px}
  .section{padding:44px 0}
  .stat{border-right:0;border-bottom:1px solid rgba(255,255,255,.08)}
}
@media (max-width:520px){
  .container{padding:0 28px}
  .contact-form{padding:28px 22px}
  .hero-actions{flex-direction:column}
  .hero-actions .btn{text-align:center}
  .footer-inner{padding:42px 28px 30px}
  .footer-bottom-inner{padding:20px 28px}
}

/* Justify long body paragraphs */
.about-text p,
.service-intro p,
.post-lead,
.post-content,
.post-content p,
.contact-intro p,
.footer-brand p{text-align:justify}

/* ===== Read more link ===== */
.read-more{
  display:inline-flex;align-items:center;gap:8px;margin-top:16px;
  color:var(--gold-deep);font-weight:500;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;
}
.read-more span{transition:transform .25s ease}
.read-more:hover{color:var(--navy)}
.read-more:hover span{transform:translateX(5px)}
.read-more.back{margin-top:0}
.service-body{display:flex;flex-direction:column}

/* ===== Our Work grid ===== */
.work{background:var(--cream)}
.work-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.work-card{
  background:#fff;border:1px solid var(--line);border-radius:22px;overflow:hidden;
  box-shadow:0 10px 30px -24px rgba(14,17,25,.4);transition:.3s ease;display:flex;flex-direction:column;
}
.work-card:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--gold)}
.work-img{display:block;height:210px;background-size:cover;background-position:center;transition:.5s ease}
.work-card:hover .work-img{transform:scale(1.04)}
.work-body{padding:24px 26px 28px;display:flex;flex-direction:column;flex:1}
.work-cat{color:var(--gold-deep);letter-spacing:.18em;text-transform:uppercase;font-size:.7rem;font-weight:600;margin-bottom:10px}
.work-body h3{font-size:1.45rem;line-height:1.2;margin-bottom:10px;color:var(--navy)}
.work-body h3 a:hover{color:var(--gold-deep)}
.work-body p{color:#4b5160;font-size:.95rem;flex:1}
.work-empty{text-align:center;color:var(--muted);font-size:1.05rem;padding:30px 0}
.work-all{text-align:center;margin-top:48px}

/* ===== Testimonials ===== */
.testimonials{background:linear-gradient(180deg,var(--cream),#fff)}
.rating-badge{display:inline-flex;align-items:center;gap:10px;margin-top:16px;background:#fff;border:1px solid var(--line);border-radius:50px;padding:8px 18px;font-weight:500;color:var(--navy);box-shadow:0 8px 20px -16px rgba(14,17,25,.5)}
.rating-badge .stars,.testi-card .stars{color:#f0b429;letter-spacing:2px}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.testi-card{
  position:relative;background:#fff;border:1px solid var(--line);border-radius:22px;padding:34px 30px 28px;
  display:flex;flex-direction:column;gap:14px;transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease;
  box-shadow:0 14px 36px -28px rgba(14,17,25,.5);overflow:hidden;
}
.testi-card::after{content:"";position:absolute;left:0;top:0;width:100%;height:4px;background:linear-gradient(90deg,var(--gold),var(--gold-deep));transform:scaleX(0);transform-origin:left;transition:transform .35s ease}
.testi-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--gold)}
.testi-card:hover::after{transform:scaleX(1)}
.testi-quote-mark{position:absolute;top:6px;right:22px;font-family:'Cormorant Garamond',serif;font-size:5.5rem;line-height:1;color:var(--gold);opacity:.18;pointer-events:none}
.testi-card .stars{font-size:1.02rem;position:relative;z-index:1}
.testi-card blockquote{font-size:1.02rem;line-height:1.75;color:#3a4150;flex:1;position:relative;z-index:1}
.testi-card figcaption{display:flex;align-items:center;gap:14px;margin-top:6px;padding-top:18px;border-top:1px solid var(--line)}
.testi-avatar{
  flex:none;width:46px;height:46px;border-radius:50%;
  background:var(--navy);color:var(--gold);display:flex;align-items:center;justify-content:center;
  font-weight:600;font-size:.95rem;letter-spacing:.04em;
}
.testi-meta{display:flex;flex-direction:column;line-height:1.3}
.testi-meta strong{color:var(--navy);font-weight:600;font-size:.98rem}
.testi-meta span{color:var(--muted);font-size:.84rem}

/* admin nav */
.admin-nav{display:flex;gap:6px;margin-left:8px}
.admin-nav a{color:rgba(255,255,255,.8);padding:6px 14px;border-radius:50px;font-size:.86rem;letter-spacing:.03em;transition:.2s}
.admin-nav a:hover{color:#fff}
.admin-nav a.active{background:var(--gold);color:var(--navy);font-weight:500}

/* ===== Single post page ===== */
.post-page{padding-top:118px}
.post-hero{position:relative;min-height:40vh;display:flex;align-items:flex-end;background-size:cover;background-position:center}
.post-hero-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(14,17,25,.92),rgba(14,17,25,.35))}
.post-hero-content{position:relative;z-index:2;color:#fff;padding:48px 24px}
.post-cat{display:inline-block;background:var(--gold);color:var(--navy);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600;padding:6px 14px;border-radius:50px;margin-bottom:16px}
.post-hero-content h1{font-size:clamp(2.2rem,5vw,3.6rem);margin-bottom:10px}
.post-date{color:rgba(255,255,255,.75);font-size:.9rem;letter-spacing:.05em}
.post-body{max-width:780px;padding:40px 24px}
.post-lead{font-size:1.25rem;color:var(--navy);font-weight:400;margin-bottom:26px;line-height:1.55}
.post-content{color:#3a4150;font-size:1.08rem;line-height:1.8}
.post-content p{margin-bottom:18px}
.post-body .read-more.back{margin-top:40px}
.post-missing{text-align:center;padding:140px 24px 100px}
.post-missing h1{font-size:2.6rem;color:var(--navy);margin-bottom:14px}
.post-missing p{color:var(--muted);margin-bottom:26px}
.related{padding:20px 24px 90px}
.related h2{font-size:2rem;color:var(--navy);margin-bottom:30px}

/* ===== Service detail page ===== */
.service-page{padding-top:118px;min-height:calc(100vh - 70px)}
.service-tagline{color:rgba(255,255,255,.9);font-size:1.15rem;font-weight:300;max-width:560px;margin-top:6px}
.service-detail{display:grid;grid-template-columns:1.7fr 1fr;gap:48px;padding:44px 24px 16px;align-items:start}
.service-intro h2{font-size:2.1rem;color:var(--navy);margin-bottom:20px}
.service-intro p{color:#3a4150;font-size:1.1rem;line-height:1.8;margin-bottom:20px}
.service-offers{background:var(--cream);border:1px solid var(--line);border-radius:22px;padding:32px 30px;position:sticky;top:96px}
.service-offers h3{font-size:1.5rem;color:var(--navy);margin-bottom:18px;position:relative;padding-bottom:14px}
.service-offers h3::after{content:"";position:absolute;left:0;bottom:0;width:44px;height:2px;background:var(--gold)}
.service-offers ul{list-style:none;margin-bottom:26px}
.service-offers li{display:flex;gap:12px;align-items:flex-start;padding:9px 0;color:var(--navy);border-bottom:1px solid var(--line);font-size:.98rem}
.service-offers li:last-of-type{border-bottom:0}
.service-offers li::before{content:"";width:8px;height:8px;margin-top:7px;background:var(--gold);transform:rotate(45deg);flex:none}
.service-projects{background:var(--cream);padding:50px 0 60px;margin-top:28px}
.service-projects .section-head{margin-bottom:32px}

/* ===== Projects listing page (legacy/optional) ===== */
.projects-page{padding-top:118px}
.page-head{background:var(--navy);color:#fff;padding:54px 0}
.page-head h1{font-size:clamp(2.2rem,5vw,3.4rem);color:#fff}
.page-head .section-eyebrow{color:var(--gold)}
.cat-filter{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin:48px 0 44px}
.cat-filter a{
  padding:9px 20px;border:1px solid var(--line);border-radius:40px;font-size:.82rem;
  letter-spacing:.08em;color:var(--navy);transition:.2s;background:#fff;
}
.cat-filter a:hover{border-color:var(--gold)}
.cat-filter a.active{background:var(--navy);color:#fff;border-color:var(--navy)}
.projects-page .work-grid{padding-bottom:90px}
.projects-page,.post-page{min-height:calc(100vh - 70px)}

@media (max-width:900px){
  .work-grid,.testi-grid{grid-template-columns:1fr 1fr}
  .service-detail{grid-template-columns:1fr;gap:36px}
  .service-offers{position:static}
}
@media (max-width:620px){
  .work-grid,.testi-grid{grid-template-columns:1fr}
}
