:root{
  --green:#49af4d;
  --green-dark:#2d7d34;
  --green-soft:#eaf7eb;
  --red:#e50914;
  --red-soft:#fff0f1;
  --ink:#151719;
  --ink-2:#22272d;
  --muted:#667085;
  --line:#e5e7eb;
  --bg:#f7f9f6;
  --card:#ffffff;
  --radius:24px;
  --radius-lg:32px;
  --header-h:82px;
  --gutter:20px;
  --shadow:0 24px 70px rgba(17,24,39,.12);
  --shadow-soft:0 14px 40px rgba(17,24,39,.08);
  --shadow-mobile:0 14px 35px rgba(17,24,39,.13);
}

*,
*::before,
*::after{
  box-sizing:border-box;
}

html{
  scroll-behavior:smooth;
  scroll-padding-top:calc(var(--header-h) + 20px);
}

body{
  margin:0;
  font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color:var(--ink);
  background:
    radial-gradient(circle at top left, rgba(73,175,77,.09), transparent 34rem),
    radial-gradient(circle at 100% 24rem, rgba(229,9,20,.055), transparent 30rem),
    var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

body.nav-open{
  overflow:hidden;
}

img{
  max-width:100%;
  display:block;
}

a{
  color:inherit;
  text-decoration:none;
}

button,
input,
textarea{
  font:inherit;
}

button{
  -webkit-tap-highlight-color:transparent;
}

.container{
  width:min(1160px, calc(100% - 40px));
  margin-inline:auto;
}

.skip-link{
  position:absolute;
  left:-999px;
  top:10px;
  background:#fff;
  color:var(--ink);
  padding:10px 14px;
  border-radius:10px;
  z-index:999;
  box-shadow:var(--shadow-soft);
}

.skip-link:focus{
  left:10px;
}

:focus-visible{
  outline:3px solid rgba(73,175,77,.55);
  outline-offset:4px;
}

.site-header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(255,255,255,.9);
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
  border-bottom:1px solid rgba(17,24,39,.08);
}

.site-header::before{
  content:"";
  position:absolute;
  inset:0 0 auto;
  height:3px;
  background:linear-gradient(90deg,var(--green),var(--red));
}

.header-inner{
  height:var(--header-h);
  display:flex;
  align-items:center;
  gap:26px;
  position:relative;
}

.brand{
  display:flex;
  align-items:center;
  gap:12px;
  min-width:max-content;
  position:relative;
  z-index:2;
}

.brand-logo{
  width:74px;
  height:54px;
  object-fit:contain;
  background:#fff;
  border-radius:14px;
  padding:4px;
  box-shadow:0 8px 24px rgba(17,24,39,.08);
}

.brand strong{
  display:block;
  font-weight:950;
  letter-spacing:-.035em;
  font-size:1.12rem;
  line-height:1;
}

.brand small{
  display:block;
  color:var(--muted);
  font-weight:750;
  font-size:.78rem;
  margin-top:4px;
}

.main-nav{
  margin-left:auto;
  display:flex;
  gap:6px;
  align-items:center;
}

.main-nav a{
  padding:11px 14px;
  border-radius:999px;
  font-weight:850;
  color:#333a42;
  font-size:.94rem;
  transition:background .2s ease, color .2s ease, transform .2s ease;
}

.main-nav a:hover,
.main-nav a.active{
  background:rgba(73,175,77,.12);
  color:var(--green-dark);
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:52px;
  border:0;
  border-radius:16px;
  padding:15px 22px;
  font-weight:950;
  cursor:pointer;
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease, border-color .2s ease;
  color:#fff;
  text-align:center;
  touch-action:manipulation;
}

.btn:hover{
  transform:translateY(-2px);
}

.btn-primary{
  background:linear-gradient(135deg,var(--red),#ff343f);
  box-shadow:0 18px 40px rgba(229,9,20,.24);
}

.btn-primary:hover{
  box-shadow:0 22px 48px rgba(229,9,20,.3);
}

.btn-outline{
  background:rgba(255,255,255,.09);
  border:1px solid rgba(255,255,255,.36);
  color:#fff;
  box-shadow:none;
}

.btn-outline:hover{
  background:rgba(255,255,255,.16);
}

.btn-full{
  width:100%;
}

.header-cta{
  margin-left:8px;
  padding:13px 18px;
  border-radius:14px;
  min-height:48px;
}

.nav-toggle{
  display:none;
  margin-left:auto;
  width:52px;
  height:52px;
  border:0;
  background:#f0f2f4;
  border-radius:16px;
  align-items:center;
  justify-content:center;
  flex-direction:column;
  gap:5px;
  cursor:pointer;
  position:relative;
  z-index:60;
}

.nav-toggle span{
  width:22px;
  height:2px;
  background:#111;
  border-radius:2px;
  transition:transform .2s ease, opacity .2s ease;
}

.nav-open .nav-toggle span:nth-child(1){
  transform:translateY(7px) rotate(45deg);
}

.nav-open .nav-toggle span:nth-child(2){
  opacity:0;
}

.nav-open .nav-toggle span:nth-child(3){
  transform:translateY(-7px) rotate(-45deg);
}

.hero{
  position:relative;
  min-height:720px;
  display:flex;
  align-items:center;
  overflow:hidden;
  background:#111;
  isolation:isolate;
}

.hero::before{
  content:"";
  position:absolute;
  width:520px;
  height:520px;
  right:-160px;
  top:80px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(73,175,77,.34), transparent 64%);
  filter:blur(4px);
  z-index:1;
  pointer-events:none;
}

.hero-img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  filter:saturate(.98) contrast(1.04);
  transform:scale(1.01);
}

.hero-overlay{
  position:absolute;
  inset:0;
  z-index:0;
  background:
    linear-gradient(90deg,rgba(7,10,12,.9) 0%,rgba(7,10,12,.72) 43%,rgba(7,10,12,.22) 100%),
    linear-gradient(180deg,rgba(7,10,12,.12),rgba(7,10,12,.72));
}

.hero-grid{
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:minmax(0,1fr) 370px;
  gap:38px;
  align-items:center;
  padding:86px 0;
}

.eyebrow,
.kicker{
  display:flex;
  align-items:center;
  gap:10px;
  color:var(--green);
  text-transform:uppercase;
  letter-spacing:.13em;
  font-size:.78rem;
  font-weight:950;
  margin:0 0 16px;
}

.eyebrow span,
.kicker::after{
  content:"";
  width:34px;
  height:3px;
  background:var(--red);
  border-radius:999px;
  flex:0 0 auto;
}

.kicker{
  justify-content:center;
}

.section-head-left .kicker,
.contact .kicker,
.about-content .kicker{
  justify-content:flex-start;
}

.hero h1{
  margin:0;
  color:#fff;
  font-size:clamp(3.2rem,7vw,6.9rem);
  line-height:1.02;
  letter-spacing:-.06em;
  font-weight:950;
  max-width:760px;
  text-wrap:balance;
}

.hero-text{
  color:rgba(255,255,255,.86);
  font-size:clamp(1.05rem,1.8vw,1.34rem);
  max-width:620px;
  margin:28px 0 34px;
}

.hero-actions{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
}

.hero-card{
  background:rgba(255,255,255,.94);
  border:1px solid rgba(255,255,255,.52);
  border-radius:28px;
  padding:26px;
  box-shadow:var(--shadow);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
}

.hero-card img{
  width:125px;
  margin-bottom:18px;
  background:#fff;
  border-radius:16px;
  padding:4px;
  box-shadow:0 10px 24px rgba(17,24,39,.08);
}

.hero-card div{
  padding:18px 0;
  border-top:1px solid var(--line);
}

.hero-card div:last-child{
  padding-bottom:0;
}

.hero-card span{
  display:block;
  color:var(--muted);
  font-size:.78rem;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.08em;
  margin-bottom:3px;
}

.hero-card a,
.hero-card strong{
  font-size:1.12rem;
  font-weight:950;
  color:var(--ink);
  overflow-wrap:anywhere;
}

.trust{
  background:#fff;
  border-bottom:1px solid var(--line);
}

.trust-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
}

.trust-item{
  padding:24px;
  border-right:1px solid var(--line);
  display:flex;
  align-items:center;
  gap:14px;
}

.trust-item:last-child{
  border-right:0;
}

.trust-item b{
  color:var(--red);
  font-weight:950;
}

.trust-item span{
  font-weight:900;
  color:#2a3036;
}

.section{
  padding:92px 0;
}

.section-head{
  text-align:center;
  max-width:760px;
  margin:0 auto 42px;
}

.section-head h2{
  font-size:clamp(2.2rem,5vw,4.4rem);
  line-height:.95;
  letter-spacing:-.06em;
  margin:0 0 18px;
  font-weight:950;
  color:var(--ink);
  text-wrap:balance;
}

.section-head p{
  font-size:1.08rem;
  color:var(--muted);
  margin:0;
}

.section-head h2::after{
  content:"";
  display:block;
  width:70px;
  height:5px;
  background:linear-gradient(90deg,var(--green),var(--red));
  border-radius:999px;
  margin:20px auto 0;
}

.section-head-left{
  text-align:left;
  margin-left:0;
}

.section-head-left h2::after{
  margin-left:0;
}

.service-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}

.service-card{
  background:
    linear-gradient(180deg,#fff,#fff),
    linear-gradient(135deg,rgba(73,175,77,.2),rgba(229,9,20,.12));
  border:1px solid rgba(229,231,235,.95);
  border-radius:var(--radius);
  padding:30px;
  box-shadow:var(--shadow-soft);
  transition:transform .24s ease, box-shadow .24s ease, border-color .24s ease;
  position:relative;
  overflow:hidden;
}

.service-card::after{
  content:"";
  position:absolute;
  inset:auto -60px -90px auto;
  width:160px;
  height:160px;
  border-radius:50%;
  background:rgba(73,175,77,.08);
  pointer-events:none;
}

.service-card:hover{
  transform:translateY(-6px);
  box-shadow:var(--shadow);
  border-color:rgba(73,175,77,.32);
}

.service-icon{
  width:64px;
  height:64px;
  border-radius:19px;
  background:linear-gradient(135deg,rgba(73,175,77,.15),rgba(229,9,20,.1));
  display:grid;
  place-items:center;
  font-size:2rem;
  color:var(--red);
  font-weight:900;
  margin-bottom:22px;
}

.service-card h3{
  font-size:1.35rem;
  letter-spacing:-.03em;
  margin:0 0 10px;
}

.service-card p{
  color:var(--muted);
  margin:0;
}

.pricing{
  background:#fff;
  position:relative;
}

.price-list{
  border:1px solid var(--line);
  border-radius:28px;
  background:#fff;
  box-shadow:var(--shadow-soft);
  overflow:hidden;
}

.price-row{
  display:grid;
  grid-template-columns:1fr 190px;
  gap:20px;
  padding:26px 30px;
  border-bottom:1px solid var(--line);
  align-items:center;
}

.price-row:last-child{
  border-bottom:0;
}

.price-row h3{
  margin:0 0 6px;
  color:var(--green-dark);
  font-size:1.35rem;
  letter-spacing:-.025em;
}

.price-row p{
  margin:0;
  color:var(--muted);
}

.price-row strong{
  font-size:1.35rem;
  color:var(--red);
  text-align:right;
  white-space:nowrap;
}

.gallery-grid{
  display:grid;
  grid-template-columns:1.2fr .9fr .9fr;
  grid-auto-rows:240px;
  gap:16px;
}

.gallery-item{
  position:relative;
  overflow:hidden;
  border:0;
  padding:0;
  border-radius:24px;
  background:#111;
  cursor:pointer;
  box-shadow:var(--shadow-soft);
}

.gallery-item img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .45s ease, filter .45s ease;
}

.gallery-item:hover img{
  transform:scale(1.06);
  filter:brightness(.84);
}

.gallery-item::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,transparent 42%,rgba(0,0,0,.72));
  opacity:.95;
}

.gallery-item span{
  position:absolute;
  left:20px;
  bottom:18px;
  color:#fff;
  font-weight:950;
  z-index:1;
}

.gallery-item.large{
  grid-row:span 2;
}

.gallery-item.wide{
  grid-column:span 2;
}

.about{
  background:#fff;
}

.about-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:56px;
  align-items:center;
}

.about-media{
  position:relative;
}

.about-media img{
  border-radius:32px;
  box-shadow:var(--shadow);
  height:520px;
  width:100%;
  object-fit:cover;
}

.experience-card{
  position:absolute;
  right:24px;
  bottom:24px;
  background:#fff;
  border:1px solid rgba(229,231,235,.9);
  border-radius:22px;
  padding:18px 20px;
  display:flex;
  gap:14px;
  align-items:center;
  box-shadow:var(--shadow-soft);
  max-width:270px;
}

.experience-card strong{
  font-size:3rem;
  line-height:1;
  color:var(--red);
  font-weight:950;
}

.experience-card span{
  font-weight:900;
}

.about-content h2{
  font-size:clamp(2.2rem,4.5vw,4.2rem);
  line-height:1;
  letter-spacing:-.06em;
  margin:0 0 20px;
  text-wrap:balance;
}

.about-content p{
  color:var(--muted);
  font-size:1.08rem;
}

.about-points{
  display:grid;
  gap:12px;
  margin-top:24px;
}

.about-points span{
  font-weight:900;
  background:linear-gradient(135deg,var(--green-soft),#fff);
  border:1px solid rgba(73,175,77,.13);
  padding:14px 16px;
  border-radius:16px;
  color:#293039;
}

.process-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
}

.process-card{
  background:linear-gradient(180deg,#fff,#f7faf7);
  border:1px solid var(--line);
  border-radius:24px;
  padding:28px;
  box-shadow:0 12px 30px rgba(17,24,39,.06);
}

.process-card b{
  display:block;
  color:var(--red);
  font-size:1.1rem;
  margin-bottom:18px;
}

.process-card h3{
  margin:0 0 8px;
  font-size:1.25rem;
  letter-spacing:-.02em;
}

.process-card p{
  margin:0;
  color:var(--muted);
}

.contact{
  background:
    radial-gradient(circle at 10% 0%,rgba(73,175,77,.24),transparent 32rem),
    radial-gradient(circle at 100% 35%,rgba(229,9,20,.22),transparent 30rem),
    linear-gradient(135deg,#151719,#20262b);
  color:#fff;
}

.contact-grid{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:28px;
  align-items:start;
}

.contact h2{
  font-size:clamp(2.4rem,5vw,4.6rem);
  line-height:.95;
  letter-spacing:-.06em;
  margin:0 0 18px;
  text-wrap:balance;
}

.contact-info p{
  color:rgba(255,255,255,.74);
  font-size:1.08rem;
}

.contact-lines{
  display:grid;
  gap:14px;
  margin-top:26px;
}

.contact-lines a,
.contact-lines > span{
  display:flex;
  align-items:center;
  gap:12px;
  color:#fff;
  font-weight:850;
}

.contact-lines span span,
.contact-lines a span{
  width:42px;
  height:42px;
  background:rgba(73,175,77,.16);
  color:var(--green);
  border:1px solid rgba(73,175,77,.22);
  border-radius:14px;
  display:grid;
  place-items:center;
  font-weight:900;
  flex:0 0 auto;
}

.contact-form{
  background:#fff;
  color:var(--ink);
  border-radius:28px;
  padding:26px;
  box-shadow:var(--shadow);
}

.form-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}

.contact-form label{
  display:block;
  margin-bottom:14px;
}

.contact-form label span{
  display:block;
  font-size:.85rem;
  font-weight:900;
  margin-bottom:7px;
}

.contact-form input,
.contact-form textarea{
  width:100%;
  border:1px solid var(--line);
  background:#f8faf9;
  border-radius:14px;
  padding:14px 15px;
  outline:0;
  transition:border-color .2s ease, box-shadow .2s ease, background .2s ease;
}

.contact-form input:focus,
.contact-form textarea:focus{
  border-color:var(--green);
  box-shadow:0 0 0 4px rgba(73,175,77,.14);
  background:#fff;
}

.contact-form textarea{
  resize:vertical;
  min-height:140px;
}

.form-note{
  min-height:22px;
  color:var(--green-dark);
  font-weight:800;
  text-align:center;
  margin:12px 0 0;
}

.site-footer{
  background:#0d0f10;
  color:#fff;
  padding:48px 0 26px;
}

.footer-grid{
  display:grid;
  grid-template-columns:1.2fr .8fr 1fr;
  gap:34px;
}

.footer-logo{
  width:130px;
  background:#fff;
  border-radius:14px;
  padding:4px;
  margin-bottom:14px;
}

.site-footer p,
.site-footer span,
.site-footer a{
  color:rgba(255,255,255,.72);
}

.site-footer a{
  display:block;
  margin:7px 0;
}

.site-footer a:hover{
  color:#fff;
}

.site-footer h3{
  margin:0 0 12px;
  color:#fff;
}

.footer-bottom{
  border-top:1px solid rgba(255,255,255,.12);
  margin-top:32px;
  padding-top:18px;
  text-align:center;
  color:rgba(255,255,255,.55);
}

.lightbox{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.9);
  display:none;
  align-items:center;
  justify-content:center;
  z-index:100;
  padding:24px;
}

.lightbox.open{
  display:flex;
}

.lightbox img{
  max-height:86vh;
  max-width:92vw;
  border-radius:18px;
}

.lightbox-close{
  position:absolute;
  right:24px;
  top:18px;
  width:48px;
  height:48px;
  border:0;
  border-radius:50%;
  background:#fff;
  color:#111;
  font-size:34px;
  line-height:1;
  cursor:pointer;
}

.mobile-cta{
  display:none;
}

.reveal{
  opacity:0;
  transform:translateY(22px);
  transition:opacity .65s ease, transform .65s ease;
}

.reveal.is-visible{
  opacity:1;
  transform:none;
}

@media (max-width: 980px){
  :root{
    --header-h:74px;
  }

  .header-cta{
    display:none;
  }

  .nav-toggle{
    display:flex;
  }

  .main-nav{
    position:fixed;
    left:var(--gutter);
    right:var(--gutter);
    top:calc(var(--header-h) + 12px);
    margin:0;
    display:grid;
    gap:4px;
    align-items:stretch;
    background:rgba(255,255,255,.98);
    border:1px solid var(--line);
    border-radius:22px;
    padding:12px;
    box-shadow:var(--shadow);
    opacity:0;
    pointer-events:none;
    transform:translateY(-8px);
    transition:opacity .2s ease, transform .2s ease;
  }

  .main-nav a{
    padding:15px 16px;
    border-radius:16px;
    font-size:1rem;
  }

  .nav-open .main-nav{
    opacity:1;
    pointer-events:auto;
    transform:none;
  }

  .hero{
    min-height:auto;
  }

  .hero-grid{
    grid-template-columns:1fr;
    padding:76px 0 54px;
  }

  .hero-card{
    max-width:460px;
  }

  .trust-grid{
    grid-template-columns:repeat(2,1fr);
  }

  .trust-item:nth-child(2){
    border-right:0;
  }

  .service-grid{
    grid-template-columns:repeat(2,1fr);
  }

  .gallery-grid{
    grid-template-columns:1fr 1fr;
    grid-auto-rows:220px;
  }

  .gallery-item.large{
    grid-row:span 1;
  }

  .gallery-item.wide{
    grid-column:span 1;
  }

  .about-grid,
  .contact-grid{
    grid-template-columns:1fr;
  }

  .about-media img{
    height:460px;
  }

  .process-grid{
    grid-template-columns:repeat(2,1fr);
  }

  .footer-grid{
    grid-template-columns:1fr 1fr;
  }

  .mobile-cta{
    position:fixed;
    left:max(14px, env(safe-area-inset-left));
    right:max(14px, env(safe-area-inset-right));
    bottom:max(14px, env(safe-area-inset-bottom));
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:10px;
    z-index:45;
  }

  .mobile-cta a{
    background:var(--ink);
    color:#fff;
    border-radius:16px;
    padding:14px;
    font-weight:950;
    text-align:center;
    box-shadow:0 14px 30px rgba(0,0,0,.22);
  }

  .mobile-cta a:last-child{
    background:linear-gradient(135deg,var(--red),#ff343f);
  }

  body{
    padding-bottom:86px;
  }
}

@media (max-width: 620px){
  :root{
    --header-h:70px;
    --gutter:14px;
    --radius:20px;
  }

  .container{
    width:min(100% - 28px,1160px);
  }

  .site-header{
    background:rgba(255,255,255,.94);
  }

  .brand{
    gap:10px;
  }

  .brand-logo{
    width:58px;
    height:46px;
    border-radius:12px;
  }

  .brand strong{
    font-size:1rem;
  }

  .brand small{
    font-size:.72rem;
  }

  .nav-toggle{
    width:48px;
    height:48px;
    border-radius:15px;
  }

  .main-nav{
    top:calc(var(--header-h) + 10px);
  }

  .hero{
    min-height:auto;
  }

  .hero::before{
    width:360px;
    height:360px;
    right:-190px;
    top:60px;
  }

  .hero-grid{
    padding:54px 0 32px;
    gap:24px;
  }

  .hero-overlay{
    background:
      linear-gradient(180deg,rgba(7,10,12,.62),rgba(7,10,12,.95)),
      linear-gradient(90deg,rgba(7,10,12,.74),rgba(7,10,12,.36));
  }

  .hero-img{
    opacity:.92;
  }

  .eyebrow,
  .kicker{
    font-size:.72rem;
    letter-spacing:.11em;
    margin-bottom:13px;
  }

  .eyebrow span,
  .kicker::after{
    width:28px;
  }

 .hero h1{
  font-size:clamp(3.05rem,17vw,4.15rem);
  line-height:1.04;
  letter-spacing:-.055em;
}

  .hero-text{
    font-size:1rem;
    margin:20px 0 24px;
  }

  .hero-actions{
    display:grid;
    gap:10px;
  }

  .btn{
    width:100%;
    min-height:52px;
    padding:14px 18px;
    border-radius:15px;
  }

  .hero-card{
    border-radius:22px;
    padding:20px;
    box-shadow:var(--shadow-mobile);
  }

  .hero-card img{
    width:104px;
    margin-bottom:14px;
  }

  .hero-card div{
    padding:15px 0;
  }

  .hero-card a,
  .hero-card strong{
    font-size:1rem;
  }

  .trust-grid,
  .service-grid,
  .process-grid,
  .footer-grid{
    grid-template-columns:1fr;
  }

  .trust-item{
    border-right:0;
    border-bottom:1px solid var(--line);
    padding:18px 4px;
  }

  .trust-item:last-child{
    border-bottom:0;
  }

  .section{
    padding:66px 0;
  }

  .section-head{
    margin-bottom:30px;
  }

  .section-head h2{
    font-size:clamp(2.25rem,13vw,3.15rem);
  }

  .section-head p{
    font-size:1rem;
  }

  .service-card{
    padding:24px;
    border-radius:22px;
  }

  .service-card:hover{
    transform:none;
  }

  .service-icon{
    width:58px;
    height:58px;
    border-radius:17px;
    font-size:1.8rem;
    margin-bottom:18px;
  }

  .price-list{
    border-radius:22px;
  }

  .price-row{
    grid-template-columns:1fr;
    gap:10px;
    padding:22px;
  }

  .price-row h3{
    font-size:1.18rem;
  }

  .price-row strong{
    text-align:left;
    font-size:1.24rem;
  }

  .gallery-grid{
    grid-template-columns:1fr;
    grid-auto-rows:250px;
    gap:12px;
  }

  .gallery-item{
    border-radius:20px;
  }

  .gallery-item:hover img{
    transform:none;
    filter:none;
  }

  .about-grid{
    gap:28px;
  }

  .about-media img{
    height:360px;
    border-radius:24px;
  }

  .experience-card{
    position:static;
    margin-top:14px;
    max-width:none;
    border-radius:20px;
  }

  .experience-card strong{
    font-size:2.55rem;
  }

  .about-content h2,
  .contact h2{
    font-size:clamp(2.25rem,13vw,3.25rem);
  }

  .about-content p,
  .contact-info p{
    font-size:1rem;
  }

  .process-card{
    padding:24px;
    border-radius:22px;
  }

  .contact{
    background:
      radial-gradient(circle at 0% 0%,rgba(73,175,77,.2),transparent 22rem),
      linear-gradient(135deg,#151719,#20262b);
  }

  .contact-grid{
    gap:24px;
  }

  .contact-lines{
    gap:12px;
  }

  .contact-lines a,
  .contact-lines > span{
    align-items:flex-start;
    overflow-wrap:anywhere;
  }

  .contact-form{
    padding:20px;
    border-radius:22px;
  }

  .form-row{
    grid-template-columns:1fr;
    gap:0;
  }

  .contact-form input,
  .contact-form textarea{
    font-size:16px;
    border-radius:13px;
  }

  .site-footer{
    padding:42px 0 24px;
  }

  .footer-bottom{
    text-align:left;
  }

  .lightbox{
    padding:14px;
  }

  .lightbox img{
    max-width:94vw;
    max-height:80vh;
    border-radius:14px;
  }

  .lightbox-close{
    right:14px;
    top:14px;
    width:44px;
    height:44px;
  }
}

@media (max-width: 380px){
  .brand strong{
    font-size:.92rem;
  }

  .brand small{
    display:none;
  }

  .hero h1{
    font-size:2.85rem;
  }

  .mobile-cta{
    grid-template-columns:1fr;
  }

  body{
    padding-bottom:140px;
  }
}

@media (prefers-reduced-motion: reduce){
  *,
  *::before,
  *::after{
    scroll-behavior:auto !important;
    transition-duration:.01ms !important;
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
  }

  .reveal{
    opacity:1;
    transform:none;
  }
}