:root{
  --grad-a:#4a83c9;
  --grad-b:#5fa7b7;
  --fg:#f4f3ef;
  --muted:rgba(244,243,239,.75);
  --soft:rgba(244,243,239,.25);
  --shadow: 0 30px 70px rgba(0,0,0,.28);
}

*{ box-sizing:border-box; }
html,body{ height:100%; }
body{
  margin:0;
  color:var(--fg);
  font-family: Montserrat, system-ui, -apple-system, Segoe UI, sans-serif;
  /* background:#0b0f0f; */
}

.hero{
  min-height:90vh;
  position:relative;
  overflow:visible;
}

.hero__bg{
  position:absolute;
  inset:0;
  background:
    radial-gradient(1400px 800px at 20% 30%, rgba(255,255,255,.06), transparent 55%),
    linear-gradient(90deg, var(--grad-a) 0%, var(--grad-b) 100%);
  filter:saturate(0.95);
  transform:scale(1.03);
}

 

.icon-btn{
  background:transparent;
  border:none;
  color:var(--fg);
  opacity:.9;
  cursor:pointer;
  padding:10px;
  border-radius:12px;
}
.icon-btn:hover{ background:rgba(255,255,255,.06); }

.slider{
  position:relative;
  z-index:5;
  padding:0 48px 40px;
}

.stage{
  display:grid;
  grid-template-columns: 1fr 1.2fr;
  align-items:center;
  gap:48px;
  max-width:1200px;
  margin:0 auto;
  min-height: calc(95vh - 160px);
}

.stage__text{
  max-width:520px;
}

.stage__kicker{
  font-weight:600;
  letter-spacing:.14em;
  opacity:.95;
  font-size:18px;
  margin-bottom:6px;
}

.stage__title{
  font-family:"Manrope";
  font-weight:700;
  font-size:100px;
  line-height:.92;
  margin:0 0 18px;
  letter-spacing:.3px;
}

.stage__desc{
  margin:0 0 26px;
  max-width:380px;
  color:var(--muted);
  font-size:14px;
  line-height:1.8;
}

.stage__cta{
  display:inline-flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
  color:var(--fg);
  font-weight:600;
  letter-spacing:.12em;
  font-size:12px;
  opacity:.95;
  position:relative;
  padding:10px 2px;
}
.stage__cta span{
  border-bottom:1px solid rgba(244,243,239,.25);
  padding-bottom:10px;
}
.stage__cta:hover{ opacity:1; }

.stage__art{
  position:relative;
  display:flex;
  justify-content:center;
  align-items:center;
  min-height:520px;
}

.stage__art::before{
  content:"";
  position:absolute;
  bottom:36px;
  width:min(560px, 88%);
  height:220px;
  border-radius:26px;
  background: linear-gradient(180deg, #f3d9b6 0%, #e6bf8c 100%);
  box-shadow:
    0 40px 60px rgba(0,0,0,.35),
    0 10px 0 rgba(0,0,0,.12);
  z-index:0;
  transform: perspective(900px) rotateX(18deg);
}

.stage__art::after{
  content:"";
  position:absolute;
  bottom:18px;
  left:50%;
  width:min(560px, 88%);
  height:80px;
  border-radius:0 0 24px 24px;
  background: linear-gradient(90deg, #c08f6e 0%, #8b5a44 100%);
  transform: translateX(-50%);
  z-index:-1;
  filter: drop-shadow(0 18px 30px rgba(0,0,0,.35));
}

.stage__num{
  position:absolute;
  top:-50px;
  right:10px;
  font-family:"Playfair Display", serif;
  font-weight:600;
  font-size:120px;
  color:rgba(244,243,239,.18);
  letter-spacing:.02em;
  user-select:none;
  pointer-events:none;
  transform:translateY(6px);
}

.stage__img{
  width:min(720px, 96%);
  height:auto;
  filter: drop-shadow(var(--shadow));
  transform: translate3d(0,-34px,0);
  will-change: transform, opacity;
  position:relative;
  z-index:1;
}

.controls{
  position:relative;
  z-index:10;
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  max-width:1200px;
  margin:0 auto;
  padding-top:24px;
}

.controls__year{
  display:flex;
  flex-direction:column;
  gap:2px;
  font-weight:600;
  letter-spacing:.08em;
  color:rgba(244,243,239,.6);
  user-select:none;
}

.controls__nav{
  display:flex;
  gap:16px;
  align-items:center;
}

.controls__socials{
  display:flex;
  align-items:center;
  gap:10px;
}

.nav-btn{
  width:46px;
  height:46px;
  border-radius:999px;
  border:none;
  cursor:pointer;
  color:rgba(244,243,239,.9);
  background:rgba(255,255,255,.12);
  backdrop-filter: blur(10px);
  display:grid;
  place-items:center;
  transition: transform .18s ease, background .18s ease;
}
.nav-btn:hover{ background:rgba(255,255,255,.18); transform:translateY(-1px); }
.nav-btn:active{ transform:translateY(0); }

.controls__social{
  width:44px;
  height:44px;
  border-radius:14px;
  display:grid;
  place-items:center;
  color:rgba(244,243,239,.7);
  border:1px solid rgba(244,243,239,.22);
  text-decoration:none;
  backdrop-filter: blur(10px);
}
.controls__social:hover{ color:rgba(244,243,239,.95); border-color:rgba(244,243,239,.35); }

/* Slide transitions (we animate the stage content on change) */
.stage.is-animating .stage__title,
.stage.is-animating .stage__desc,
.stage.is-animating .stage__cta,
.stage.is-animating .stage__kicker{
  opacity:0;
  transform: translateY(14px);
}
.stage__title,
.stage__desc,
.stage__cta,
.stage__kicker{
  transition: opacity .5s ease, transform .5s ease;
}

.stage.is-animating .stage__img{
  opacity:0;
  transform: translateY(-8px) scale(0.985);
}
.stage__img{
  transition: opacity .55s ease, transform .6s ease;
}

.stage.is-animating .stage__num{
  opacity:0;
  transform: translateY(18px);
}
.stage__num{
  transition: opacity .55s ease, transform .6s ease;
}





/* =========================
   NAVBAR (Topbar)
========================= */
.topbar{
  position: sticky;
  top: 0;
  z-index: 50;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 10px 28px;
  background:
    radial-gradient(1400px 800px at 20% 30%, rgba(255,255,255,.06), transparent 55%),
    linear-gradient(90deg, var(--grad-a) 0%, var(--grad-b) 100%);
  border-bottom: 1px solid rgba(255,255,255,0.12);
}

.brand{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  color: inherit;
}

.brand__mark{
  width: 34px;
  height: 34px;
  border-radius: 10px;
  background: rgba(255,255,255,0.14);
  border: 1px solid rgba(255,255,255,0.18);
  backdrop-filter: blur(8px);
}

.brand__text{
  font-family: "Playfair Display", serif;
  font-weight: 700;
  letter-spacing: .2px;
  font-size: 18px;
}

.brand__logo{
  width: 150px;
  height: 44px;
  object-fit: contain;
  display: block;
}

.nav{
  display: flex;
  align-items: center;
  justify-content: center;
  flex: 1;
}

.nav__menu{
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 22px;
  margin: 0;
  padding: 0;
}

.nav__link{
  font-family: "Montserrat", sans-serif;
  font-weight: 500;
  font-size: 15px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  text-decoration: none;
  color: rgba(255,255,255,0.86);
  padding: 10px 10px;
  border-radius: 12px;
  transition: background .2s ease, color .2s ease, transform .2s ease;
}

.nav__link:hover{
  background: rgba(255,255,255,0.10);
  color: rgba(255,255,255,0.95);
  transform: translateY(-1px);
}

.nav__link.is-active{
 /* background: rgba(255,255,255,0.14);
  color: #fff;
  border: 1px solid rgba(255,255,255,0.16);
*/
}

.topbar__actions{
  display: flex;
  align-items: center;
  gap: 10px;
}
.topbar__search{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.2);
  background: rgba(255,255,255,0.12);
  backdrop-filter: blur(10px);
}
.topbar__searchInput{
  border: 0;
  background: transparent;
  outline: none;
  color: rgba(255,255,255,0.9);
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: 12px;
  width: 180px;
}
.topbar__searchInput::placeholder{
  color: rgba(255,255,255,0.6);
}
.topbar__searchBtn{
  border: 0;
  background: transparent;
  color: rgba(255,255,255,0.9);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 6px;
  border-radius: 999px;
}
.topbar__searchBtn:hover{
  background: rgba(255,255,255,0.12);
}

.topbar__cta{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 14px;
  border-radius: 14px;
  text-decoration: none;
  font-family: "Montserrat", sans-serif;
  font-weight: 600;
  font-size: 13px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #0b1415;
  background: rgba(255,255,255,0.88);
  border: 1px solid rgba(255,255,255,0.35);
  transition: transform .2s ease, background .2s ease;
}

/* Product description tables */
.product-single__content table{
  width: 100%;
  border-collapse: collapse;
}
.product-single__content td{
  border: 1px solid #e5e5e5;
  padding: 8px 10px;
  vertical-align: top;
}
.product-single__content .thead{
  font-weight: 600;
  background: #f7f7f7;
}

/* Welcome popup */
.welcome-popup{
  position: fixed;
  inset: 0;
  display: grid;
  place-items: center;
  z-index: 9999;
  opacity: 0;
  visibility: hidden;
  transition: opacity .25s ease, visibility .25s ease;
}
.welcome-popup.is-open{
  opacity: 1;
  visibility: visible;
}
.welcome-popup__backdrop{
  position: absolute;
  inset: 0;
  border: 0;
  background: rgba(0,0,0,.55);
}
.welcome-popup__panel{
  position: relative;
  z-index: 1;
  width: min(760px, 92vw);
  background: #fff;
  color: #111;
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 30px 80px rgba(0,0,0,.35);
  display: grid;
  grid-template-columns: 1fr 1fr;
}
.welcome-popup__media img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.welcome-popup__content{
  padding: 32px 30px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.welcome-popup__title{
  margin: 0;
  font-family: "Playfair Display", serif;
  font-size: 28px;
}
.welcome-popup__text{
  margin: 0;
  color: #444;
  line-height: 1.6;
}
.welcome-popup__cta{
  align-self: flex-start;
  margin-top: 8px;
  text-decoration: none;
  background: #111;
  color: #fff;
  padding: 10px 16px;
  border-radius: 12px;
  font-weight: 600;
  letter-spacing: .04em;
}
.welcome-popup__close{
  position: absolute;
  top: 12px;
  right: 12px;
  width: 34px;
  height: 34px;
  border-radius: 999px;
  border: 0;
  background: rgba(0,0,0,.08);
  cursor: pointer;
  font-size: 20px;
  line-height: 1;
}
@media (max-width: 760px){
  .welcome-popup__panel{
    grid-template-columns: 1fr;
  }
  .welcome-popup__content{
    padding: 24px;
  }
}

.topbar__cta:hover{
  transform: translateY(-1px);
  background: rgba(255,255,255,0.96);
}

/* =========================
   Mobile menu
========================= */
.nav__toggle{
  display: none;
  width: 44px;
  height: 44px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.18);
  background: rgba(255,255,255,0.10);
  backdrop-filter: blur(10px);
  cursor: pointer;
  padding: 10px;
}

.nav__toggle span{
  display: block;
  height: 2px;
  margin: 6px 0;
  background: rgba(255,255,255,0.92);
  border-radius: 2px;
}

@media (max-width: 920px){
  .nav{
    justify-content: flex-end;
  }

  .nav__toggle{
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }

  .nav__menu{
    position: absolute;
    top: 72px;
    left: 18px;
    right: 18px;
    display: none;
    flex-direction: column;
    gap: 6px;
    padding: 14px;
    border-radius: 18px;
    background: rgba(10, 16, 18, 0.55);
    border: 1px solid rgba(255,255,255,0.14);
    backdrop-filter: blur(14px);
  }

  .nav__menu.is-open{
    display: flex;
  }

  .nav__link{
    width: 100%;
    text-align: center;
    padding: 12px 12px;
    letter-spacing: 0.14em;
  }
}

@media (max-width: 520px){
  .topbar{
    padding: 10px 16px;
  }
  .brand__text{
    font-size: 16px;
  }
  .topbar__search{
    padding: 4px 8px;
  }
  .topbar__searchInput{
    width: 120px;
  }
  .stage__title{ font-size: 44px; }
  .stage__desc{ font-size: 13px; }
  .stage__art{ min-height: 300px; }
  .stage__art::before{
    width: min(420px, 92%);
    height: 150px;
  }
  .stage__art::after{
    width: min(420px, 92%);
    height: 60px;
  }
}




@media (max-width: 980px){
  .topbar{ padding:10px 22px; }
  .slider{ padding:0 22px 30px; }
  .stage{
    grid-template-columns: 1fr;
    gap:18px;
    min-height: calc(100vh - 140px);
  }
  .stage__title{ font-size:64px; }
  .stage__desc{ max-width: 520px; }
  .stage__art{ min-height: 380px; }
  .stage__num{ right:0; font-size:96px; }
  .stage__art::before{
    bottom:30px;
    height:180px;
  }
  .stage__img{ transform: translate3d(0,-24px,0); }
}

@media (prefers-reduced-motion: reduce){
  *{ transition:none !important; }
}






















/* ===== Services Section (like shared design) ===== */
.services{
  padding: clamp(48px, 6vw, 88px) 16px;
  background:
    radial-gradient(1200px 600px at 50% 0%, rgba(0,0,0,.05), transparent 60%),
    #f6f7f9;
}

.services__container{
  max-width: 1100px;
  margin: 0 auto;
}

.services__head{
  text-align: center;
  margin-bottom: 34px;
}

.services__title{
  margin: 0 0 8px;
  font-family: "Playfair Display", serif;
  font-weight: 700;
  letter-spacing: .2px;
  font-size: clamp(32px, 4vw, 54px);
  color: #2b2f36;
}

.services__subtitle{
  margin: 0;
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: clamp(14px, 1.8vw, 18px);
  color: #6b7280;
}

.services__subtitle::after{
  content: "";
  display: block;
  width: 74px;
  height: 3px;
  margin: 14px auto 0;
  background: #ff6a3d;
  border-radius: 999px;
  opacity: .85;
}

.services__grid{
  display: grid;
  gap: 22px;
}

/* 4-column layout per row: left text | left icon | right icon | right text */
.services__row{
  display: grid;
  grid-template-columns: 1.35fr 92px 92px 1.35fr;
  align-items: center;
  column-gap: 22px;
}

.service__text{
  max-width: 360px;
}

.service--left .service__text{
  margin-left: auto;
  text-align: right;
}

.service--right .service__text{
  margin-right: auto;
  text-align: left;
}

.service__title{
  margin: 0 0 6px;
  font-family: "Montserrat", system-ui, sans-serif;
  font-weight: 600;
  font-size: 18px;
  color: #2b2f36;
}

.service__desc{
  margin: 0;
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: 13px;
  line-height: 1.6;
  color: #7b8492;
}

/* Icon box in the center */
.service__icon{
  width: 86px;
  height: 86px;
  background: var(--bg, #64748b);
  border-radius: 18px;
  display: grid;
  place-items: center;
  box-shadow: 0 18px 30px rgba(15, 23, 42, 0.15);
}

.service__icon svg{
  width: 40px;
  height: 40px;
  color: #fff;
  opacity: .95;
}

/* Responsive: stack nicely on small screens */
@media (max-width: 900px){
  .services__row{
    grid-template-columns: 1fr 86px 86px 1fr;
  }
  .service__text{ max-width: 100%; }
}

@media (max-width: 700px){
  .services__row{
    grid-template-columns: 1fr;
    gap: 14px;
    padding: 18px;
    background: rgba(255,255,255,.65);
    border: 1px solid rgba(17, 24, 39, 0.06);
    border-radius: 18px;
    backdrop-filter: blur(6px);
  }

  .service--left .service__text,
  .service--right .service__text{
    text-align: left;
    margin: 0;
  }

  .service__icon{
    width: 72px;
    height: 72px;
    border-radius: 16px;
    box-shadow: 0 14px 26px rgba(15, 23, 42, 0.12);
  }

  .service__icon svg{
    width: 34px;
    height: 34px;
  }

  /* place icons between the two texts */
  .services__row > .service__icon{ justify-self: start; }
}
















/* ===== Best Selling Products (aligned with Services section) ===== */
.bestsellers{
  padding: clamp(48px, 6vw, 88px) 16px; /* same rhythm as services */
  background: #fff; /* alternate from services gray */
}

.bestsellers__container{
  max-width: 1100px;           /* same container width */
  margin: 0 auto;
}

.bestsellers__head{
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 26px;         /* close to services spacing */
}

.bestsellers__headText{
  min-width: 0;
}

.bestsellers__title{
  margin: 0 0 8px;
  font-family: "Playfair Display", serif; /* same as services title */
  font-weight: 700;
  letter-spacing: .2px;
  font-size: clamp(28px, 3.6vw, 44px);
  color: #2b2f36;
}

.bestsellers__subtitle{
  margin: 0;
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: clamp(14px, 1.8vw, 18px);
  color: #6b7280;
  line-height: 1.6;
}

/* same accent underline style as Services */
.bestsellers__subtitle::after{
  content: "";
  display: block;
  width: 74px;
  height: 3px;
  margin-top: 14px;
  background: #ff6a3d; /* same accent */
  border-radius: 999px;
  opacity: .85;
}

.bestsellers__all{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  border-radius: 999px;
  font-family: "Montserrat", system-ui, sans-serif;
  font-weight: 700;
  font-size: 12.5px;
  text-decoration: none;
  color: #111827;
  border: 1px solid rgba(17, 24, 39, .12);
  background: rgba(17, 24, 39, .02);
  transition: transform .2s ease, border-color .2s ease, background .2s ease;
}

.bestsellers__all:hover{
  transform: translateY(-1px);
  border-color: rgba(17, 24, 39, .20);
  background: rgba(17, 24, 39, .04);
}

.bestsellers__grid{
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

/* Card styling aligned with your rounded + soft shadow style */
.product-card{
  border-radius: 18px;
  overflow: hidden;
  background: #fff;
  border: 1px solid rgba(17, 24, 39, .08);
  box-shadow: 0 18px 30px rgba(15, 23, 42, .08);
  display: flex;
  flex-direction: column;
}

.product-card__media{
  position: relative;
  display: block;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: #f3f4f6;
}

.product-card__media img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transform: scale(1.02);
  transition: transform .35s ease;
}

.product-card:hover .product-card__media img{
  transform: scale(1.08);
}

.product-card__badge{
  position: absolute;
  top: 12px;
  left: 12px;
  padding: 7px 10px;
  border-radius: 999px;
  font-family: "Montserrat", system-ui, sans-serif;
  font-weight: 800;
  font-size: 11px;
  letter-spacing: .2px;
  color: #111827;
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(17, 24, 39, .10);
}

.product-card__badge--sale{ color: #b42318; }

.product-card__body{
  padding: 14px 14px 16px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.product-card__meta{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.product-card__category{
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: 12px;
  color: #6b7280;
}

.product-card__rating{
  font-family: "Montserrat", system-ui, sans-serif;
  font-weight: 800;
  font-size: 12px;
  color: #111827;
  background: rgba(17, 24, 39, .04);
  padding: 6px 8px;
  border-radius: 999px;
  border: 1px solid rgba(17, 24, 39, .08);
}

.product-card__title{
  margin: 0;
  font-family: "Montserrat", system-ui, sans-serif;
  font-weight: 800;
  font-size: 15px;
  line-height: 1.35;
}

.product-card__title a{
  color: #111827;
  text-decoration: none;
}

.product-card__desc{
  margin: 0;
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: 13px;
  line-height: 1.6;
  color: #6b7280;
}

.product-card__bottom{
  margin-top: 6px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.product-card__price--new{
  font-family: "Montserrat", system-ui, sans-serif;
  font-weight: 900;
  font-size: 14px;
  color: #111827;
}

.product-card__price--old{
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: 12px;
  color: #9ca3af;
  text-decoration: line-through;
}

/* Button matches modern dark CTA vibe */
.product-card__btn{
  border: 0;
  border-radius: 999px;
  padding: 10px 12px;
  font-family: "Montserrat", system-ui, sans-serif;
  font-weight: 800;
  font-size: 12px;
  cursor: pointer;
  color: #fff;
  background: #111827;
  transition: transform .2s ease, opacity .2s ease;
}

.product-card__btn:hover{
  transform: translateY(-1px);
  opacity: .92;
}

/* Responsive */
@media (max-width: 1000px){
  .bestsellers__grid{ grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 760px){
  .bestsellers__head{ flex-direction: column; align-items: flex-start; }
  .bestsellers__grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 460px){
  .bestsellers__grid{ grid-template-columns: 1fr; }
}




























/* ===== Recent Projects (card slider) ===== */
.projects{
  padding: clamp(48px, 6vw, 88px) 16px;
  background: #f6f7f9; /* same vibe as services */
}

.projects__container{
  max-width: 1100px;
  margin: 0 auto;
}

.projects__head{
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 26px;
}

.projects__title{
  margin: 0 0 8px;
  font-family: "Playfair Display", serif;
  font-weight: 700;
  letter-spacing: .2px;
  font-size: clamp(28px, 3.6vw, 44px);
  color: #2b2f36;
}

.projects__subtitle{
  margin: 0;
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: clamp(14px, 1.8vw, 18px);
  color: #6b7280;
  line-height: 1.6;
}

.projects__subtitle::after{
  content: "";
  display: block;
  width: 74px;
  height: 3px;
  margin-top: 14px;
  background: #ff6a3d;
  border-radius: 999px;
  opacity: .85;
}

.projects__controls{
  display: flex;
  gap: 10px;
}

.projects__btn{
  width: 44px;
  height: 44px;
  border-radius: 999px;
  border: 1px solid rgba(17, 24, 39, .12);
  background: rgba(255,255,255,.85);
  box-shadow: 0 14px 22px rgba(15, 23, 42, .10);
  cursor: pointer;
  font-size: 20px;
  line-height: 1;
  font-weight: 900;
  color: #111827;
  transition: transform .2s ease, opacity .2s ease, border-color .2s ease;
}

.projects__btn:hover{
  transform: translateY(-1px);
  border-color: rgba(17, 24, 39, .2);
  opacity: .95;
}

.projects__trackWrap{
  position: relative;
}

.projects__track{
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: calc((100% - 36px) / 3); /* 3 cards desktop */
  gap: 18px;

  overflow-x: auto;
  padding: 6px 2px 18px;

  scroll-snap-type: x mandatory;
  scroll-padding-left: 2px;
  -webkit-overflow-scrolling: touch;

  scrollbar-width: none;
}
.projects__track::-webkit-scrollbar{ display:none; }

/* Project Card */
.project-card{
  scroll-snap-align: start;
  border-radius: 18px;
  overflow: hidden;
  background: #fff;
  border: 1px solid rgba(17, 24, 39, .08);
  box-shadow: 0 18px 30px rgba(15, 23, 42, .08);
  display: flex;
  flex-direction: column;
}

.project-card__media{
  position: relative;
  display: block;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: #e5e7eb;
}

.project-card__media img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transform: scale(1.02);
  transition: transform .35s ease;
}

.project-card:hover .project-card__media img{
  transform: scale(1.08);
}

.project-card__tag{
  position: absolute;
  top: 12px;
  left: 12px;
  padding: 7px 10px;
  border-radius: 999px;
  font-family: "Montserrat", system-ui, sans-serif;
  font-weight: 800;
  font-size: 11px;
  letter-spacing: .2px;
  color: #111827;
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(17, 24, 39, .10);
}

.project-card__tag--alt{
  color: #0f766e;
}

.project-card__body{
  padding: 14px 14px 16px;
  display: grid;
  gap: 10px;
}

.project-card__title{
  margin: 0;
  font-family: "Montserrat", system-ui, sans-serif;
  font-weight: 900;
  font-size: 16px;
  line-height: 1.3;
}

.project-card__title a{
  color: #111827;
  text-decoration: none;
}

.project-card__desc{
  margin: 0;
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: 13px;
  line-height: 1.6;
  color: #6b7280;
}

.project-card__meta{
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: 12px;
  color: #6b7280;
}

.project-card__metaDot{
  opacity: .6;
}

.project-card__bottom{
  margin-top: 4px;
}

.project-card__link{
  font-family: "Montserrat", system-ui, sans-serif;
  font-weight: 800;
  font-size: 12.5px;
  text-decoration: none;
  color: #111827;
}

.project-card__link:hover{
  text-decoration: underline;
}

/* Dots */
.projects__dots{
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-top: 14px;
}

.projects__dot{
  width: 9px;
  height: 9px;
  border-radius: 999px;
  border: 1px solid rgba(17, 24, 39, .18);
  background: rgba(17, 24, 39, .06);
  cursor: pointer;
  transition: transform .2s ease, background .2s ease;
}

.projects__dot.is-active{
  background: #111827;
  transform: scale(1.1);
}

/* Responsive */
@media (max-width: 1000px){
  .projects__track{ grid-auto-columns: calc((100% - 18px) / 2); } /* 2 cards */
}
@media (max-width: 760px){
  .projects__head{ flex-direction: column; align-items: flex-start; }
  .projects__controls{ align-self: flex-end; }
}
@media (max-width: 520px){
  .projects__track{ grid-auto-columns: 100%; } /* 1 card */
}















/* ===== Our Happy Customers (Testimonials) ===== */
.testimonials{
  padding: clamp(48px, 6vw, 88px) 16px;
  background: #fff; /* alternate from projects/services */
}
.testimonials__container{ max-width: 1100px; margin: 0 auto; }

.testimonials__head{
  display:flex; align-items:flex-end; justify-content:space-between; gap:16px;
  margin-bottom: 26px;
}
.testimonials__title{
  margin:0 0 8px;
  font-family:"Playfair Display", serif;
  font-weight:700;
  letter-spacing:.2px;
  font-size: clamp(28px, 3.6vw, 44px);
  color:#2b2f36;
}
.testimonials__subtitle{
  margin:0;
  font-family:"Montserrat", system-ui, sans-serif;
  font-size: clamp(14px, 1.8vw, 18px);
  color:#6b7280;
  line-height:1.6;
}
.testimonials__subtitle::after{
  content:"";
  display:block;
  width:74px; height:3px; margin-top:14px;
  background:#ff6a3d;
  border-radius:999px; opacity:.85;
}

.testimonials__controls{ display:flex; gap:10px; }
.testimonials__btn{
  width:44px; height:44px;
  border-radius:999px;
  border:1px solid rgba(17,24,39,.12);
  background: rgba(17,24,39,.02);
  box-shadow: 0 14px 22px rgba(15,23,42,.10);
  cursor:pointer;
  font-size:20px;
  font-weight:900;
  color:#111827;
  transition: transform .2s ease, opacity .2s ease, border-color .2s ease;
}
.testimonials__btn:hover{ transform: translateY(-1px); border-color: rgba(17,24,39,.20); opacity:.95; }

.testimonials__layout{
  display:grid;
  grid-template-columns: 320px 1fr;
  gap: 18px;
  align-items:start;
}

/* Stats cards */
.tstats{ display:grid; gap: 12px; }
.tstats__card{
  border-radius: 18px;
  background: #f6f7f9;
  border: 1px solid rgba(17,24,39,.08);
  box-shadow: 0 18px 30px rgba(15,23,42,.06);
  padding: 16px;
}
.tstats__num{
  font-family:"Montserrat", system-ui, sans-serif;
  font-weight: 900;
  font-size: 28px;
  color:#111827;
  line-height:1;
}
.tstats__label{
  margin-top: 8px;
  font-family:"Montserrat", system-ui, sans-serif;
  color:#6b7280;
  font-size: 13px;
  line-height:1.6;
}

/* Slider track */
.testimonials__trackWrap{ position:relative; }
.testimonials__track{
  display:grid;
  grid-auto-flow: column;
  grid-auto-columns: calc((100% - 18px) / 2); /* 2 cards desktop */
  gap: 18px;

  overflow-x:auto;
  padding: 6px 2px 18px;
  scroll-snap-type: x mandatory;
  scroll-padding-left: 2px;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.testimonials__track::-webkit-scrollbar{ display:none; }

.tcard{
  scroll-snap-align: start;
  border-radius: 18px;
  background: #fff;
  border: 1px solid rgba(17,24,39,.08);
  box-shadow: 0 18px 30px rgba(15,23,42,.08);
  padding: 16px;
  display:grid;
  gap: 12px;
}

.tcard__top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  flex-wrap: wrap;
}
.tcard__avatar{
  width: 44px; height:44px;
  border-radius: 14px;
  display:grid; place-items:center;
  background: #111827;
  color:#fff;
  font-family:"Montserrat", system-ui, sans-serif;
  font-weight:900;
  font-size: 13px;
}
.tcard__who{ min-width:0; }
.tcard__name{
  margin:0;
  font-family:"Montserrat", system-ui, sans-serif;
  font-weight: 900;
  font-size: 14px;
  color:#111827;
  line-height:1.2;
}
.tcard__role{
  margin:2px 0 0;
  font-family:"Montserrat", system-ui, sans-serif;
  font-size: 12px;
  color:#6b7280;
}
.tcard__rating{
  font-family:"Montserrat", system-ui, sans-serif;
  font-weight:900;
  font-size: 12px;
  color:#111827;
  background: rgba(17,24,39,.04);
  border: 1px solid rgba(17,24,39,.08);
  padding: 6px 8px;
  border-radius: 999px;
  white-space: nowrap;
}

.tcard__text{
  margin:0;
  font-family:"Montserrat", system-ui, sans-serif;
  color:#4b5563;
  font-size: 13px;
  line-height: 1.7;
}

.tcard__footer{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
}
.tcard__tag{
  display:inline-flex;
  padding: 7px 10px;
  border-radius: 999px;
  font-family:"Montserrat", system-ui, sans-serif;
  font-weight: 800;
  font-size: 11px;
  color:#111827;
  background: rgba(255,106,61,.12);
  border: 1px solid rgba(255,106,61,.25);
}
.tcard__date{
  font-family:"Montserrat", system-ui, sans-serif;
  font-size: 12px;
  color:#9ca3af;
}

/* Dots */
.testimonials__dots{
  display:flex;
  justify-content:center;
  gap: 8px;
  margin-top: 12px;
}
.testimonials__dot{
  width:9px; height:9px;
  border-radius:999px;
  border:1px solid rgba(17,24,39,.18);
  background: rgba(17,24,39,.06);
  cursor:pointer;
  transition: transform .2s ease, background .2s ease;
}
.testimonials__dot.is-active{ background:#111827; transform: scale(1.1); }

/* Responsive */
@media (max-width: 1000px){
  .testimonials__layout{ grid-template-columns: 1fr; }
  .tstats{ grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 900px){
  .testimonials__track{ grid-auto-columns: 100%; } /* 1 card */
  .tstats{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 760px){
  .testimonials__head{ flex-direction: column; align-items:flex-start; }
  .testimonials__controls{ align-self: flex-start; }
  .tstats{ grid-template-columns: 1fr; }
}
@media (max-width: 520px){
  .tcard{ padding: 14px; }
  .tcard__avatar{ width: 38px; height: 38px; border-radius: 12px; }
  .tcard__name{ font-size: 13px; }
  .tcard__role{ font-size: 11px; }
  .tcard__rating{
    flex-basis: 100%;
    order: 3;
    justify-self: flex-start;
  }
}

/* ===== Contact Us ===== */
.contact{
  padding: clamp(48px, 6vw, 88px) 16px;
  background:
    radial-gradient(1200px 600px at 50% 0%, rgba(0,0,0,.05), transparent 60%),
    #f6f7f9;
}
.contact__container{ max-width: 1100px; margin: 0 auto; }

.contact__head{ text-align:center; margin-bottom: 26px; }
.contact__title{
  margin:0 0 8px;
  font-family:"Playfair Display", serif;
  font-weight:700;
  letter-spacing:.2px;
  font-size: clamp(28px, 3.6vw, 44px);
  color:#2b2f36;
}
.contact__subtitle{
  margin:0;
  font-family:"Montserrat", system-ui, sans-serif;
  font-size: clamp(14px, 1.8vw, 18px);
  color:#6b7280;
  line-height:1.6;
}
.contact__subtitle::after{
  content:"";
  display:block;
  width:74px; height:3px; margin:14px auto 0;
  background:#ff6a3d;
  border-radius:999px; opacity:.85;
}

.contact__grid{
  display:grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 18px;
  align-items: start;
}

/* Info */
.contact__info{ display:grid; gap: 12px; }
.cinfo{
  display:flex;
  gap: 12px;
  align-items:flex-start;
  padding: 14px;
  border-radius: 18px;
  background:#fff;
  border:1px solid rgba(17,24,39,.08);
  box-shadow: 0 18px 30px rgba(15,23,42,.08);
}
.cinfo__icon{
  width:44px; height:44px;
  border-radius: 16px;
  background:#111827;
  color:#fff;
  display:grid; place-items:center;
  flex: 0 0 auto;
}
.cinfo__icon svg{ width:22px; height:22px; }
.cinfo__title{
  margin:0;
  font-family:"Montserrat", system-ui, sans-serif;
  font-weight: 900;
  font-size: 13px;
  color:#111827;
}
.cinfo__text{
  margin:6px 0 0;
  font-family:"Montserrat", system-ui, sans-serif;
  font-size: 13px;
  color:#6b7280;
  line-height:1.6;
}
.cinfo__text a{ color:#111827; text-decoration:none; font-weight:800; }
.cinfo__text a:hover{ text-decoration: underline; }

.cinfo--note{
  display:block;
}
.cinfo--note .cinfo__title{ margin-bottom: 6px; }

/* Form */
.contact__form{
  padding: 16px;
  border-radius: 18px;
  background:#fff;
  border:1px solid rgba(17,24,39,.08);
  box-shadow: 0 18px 30px rgba(15,23,42,.08);
  display:grid;
  gap: 12px;
}
.cform__row{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.cform__label{
  display:grid;
  gap: 8px;
  font-family:"Montserrat", system-ui, sans-serif;
  font-weight: 800;
  font-size: 12px;
  color:#111827;
}
.cform__input, .cform__textarea{
  width:100%;
  border-radius: 14px;
  border:1px solid rgba(17,24,39,.12);
  background: rgba(17,24,39,.02);
  padding: 12px 12px;
  font-family:"Montserrat", system-ui, sans-serif;
  font-size: 13px;
  color:#111827;
  outline: none;
}
.cform__textarea{ resize: vertical; min-height: 120px; }
.cform__input:focus, .cform__textarea:focus{
  border-color: rgba(255,106,61,.45);
  box-shadow: 0 0 0 4px rgba(255,106,61,.14);
}

.cform__btn{
  border:0;
  border-radius: 999px;
  padding: 12px 14px;
  font-family:"Montserrat", system-ui, sans-serif;
  font-weight: 900;
  font-size: 12px;
  cursor:pointer;
  color:#fff;
  background:#111827;
  transition: transform .2s ease, opacity .2s ease;
}
.cform__btn:hover{ transform: translateY(-1px); opacity:.92; }

.cform__hint{
  margin: 2px 0 0;
  font-family:"Montserrat", system-ui, sans-serif;
  font-size: 12px;
  color:#9ca3af;
  line-height: 1.6;
}

/* Map */
.contact__map{
  margin-top: 18px;
  border-radius: 18px;
  overflow:hidden;
  border:1px solid rgba(17,24,39,.08);
  box-shadow: 0 18px 30px rgba(15,23,42,.08);
  background:#fff;
}
.contact__mapInner{
  min-height: 240px;
  display:grid;
  place-items:center;
  gap: 6px;
  font-family:"Montserrat", system-ui, sans-serif;
  color:#6b7280;
}

/* Responsive */
@media (max-width: 900px){
  .contact__grid{ grid-template-columns: 1fr; }
  .cform__row{ grid-template-columns: 1fr; }
}



















/* ===== Footer ===== */
.site-footer{
  padding: 48px 16px 26px;
  background:
    radial-gradient(1400px 800px at 20% 30%, rgba(255,255,255,.06), transparent 55%),
    linear-gradient(90deg, var(--grad-a) 0%, var(--grad-b) 100%);
  color: rgba(255,255,255,.86);
  position: relative;
  overflow: hidden;
}

.site-footer::before{
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(120deg, rgba(255,255,255,.05) 0%, transparent 45%),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size: 100% 100%, 36px 36px;
  opacity: .25;
  pointer-events: none;
}

.site-footer__container{
  max-width: 1120px;
  margin: 0 auto;
  position: relative;
}

.site-footer__promo{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 18px 22px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.14);
  background: linear-gradient(120deg, rgba(255,123,86,.18), rgba(255,255,255,.04));
  box-shadow: 0 18px 40px rgba(0,0,0,.25);
  margin-bottom: 20px;
}
.footer-promo__eyebrow{
  margin: 0 0 6px;
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: 12px;
  letter-spacing: .24em;
  text-transform: uppercase;
  color: rgba(255,255,255,.7);
}
.footer-promo__title{
  margin: 0;
  font-family: "Playfair Display", serif;
  font-size: clamp(20px, 2.2vw, 26px);
  color: rgba(255,255,255,.96);
}
.footer-promo__actions{
  display: inline-flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.footer-promo__btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 12px 18px;
  border-radius: 14px;
  text-decoration: none;
  font-family: "Montserrat", system-ui, sans-serif;
  font-weight: 800;
  font-size: 12px;
  color: #0a121c;
  background: #ff8c54;
  box-shadow: 0 10px 20px rgba(255,140,84,.25);
  transition: transform .2s ease, box-shadow .2s ease, opacity .2s ease;
}
.footer-promo__btn:hover{
  transform: translateY(-1px);
  box-shadow: 0 12px 26px rgba(255,140,84,.32);
  opacity: .95;
}
.footer-promo__link{
  color: rgba(255,255,255,.86);
  text-decoration: none;
  font-family: "Montserrat", system-ui, sans-serif;
  font-weight: 700;
  font-size: 12px;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.footer-promo__link:hover{ color: rgba(255,255,255,1); }

.site-footer__grid{
  display: grid;
  grid-template-columns: 1.35fr 1fr 1fr 1.2fr;
  gap: 20px;
  padding: 20px;
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.10);
  background: linear-gradient(135deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  box-shadow: 0 24px 50px rgba(0,0,0,.28);
  backdrop-filter: blur(6px);
}

.footer-col{ min-width: 0; }

.footer-title{
  margin: 6px 0 12px;
  font-family: "Montserrat", system-ui, sans-serif;
  font-weight: 900;
  font-size: 13px;
  letter-spacing: .25px;
  text-transform: uppercase;
  color: rgba(255,255,255,.92);
}

.footer-text{
  margin: 0 0 12px;
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: 13px;
  line-height: 1.7;
  color: rgba(255,255,255,.70);
}

/* Brand */
.footer-brand__logo{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  color: rgba(255,255,255,.95);
  font-family: "Playfair Display", serif;
  font-weight: 700;
  font-size: 20px;
}
.footer-brand__logo img{
  width: 42px;
  height: 42px;
  object-fit: contain;
  display: block;
}

.footer-brand__text{
  margin: 12px 0 14px;
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: 13px;
  line-height: 1.75;
  color: rgba(255,255,255,.70);
}

/* Social */
.footer-social{
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.footer-social__link{
  width: 40px;
  height: 40px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  text-decoration: none;
  color: rgba(255,255,255,.9);
  border: 1px solid rgba(255,255,255,.12);
  background: linear-gradient(145deg, rgba(255,255,255,.08), rgba(255,255,255,.02));
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.04);
  transition: transform .2s ease, background .2s ease, border-color .2s ease, box-shadow .2s ease;
}
.footer-social__link:hover{
  transform: translateY(-1px);
  background: rgba(255,255,255,.10);
  border-color: rgba(255,255,255,.2);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.1), 0 8px 18px rgba(0,0,0,.25);
}

/* Links */
.footer-links{
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 10px;
}
.footer-links a{
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: 13px;
  color: rgba(255,255,255,.72);
  text-decoration: none;
  transition: color .2s ease, transform .2s ease;
}
.footer-links a:hover{
  color: rgba(255,255,255,.95);
  transform: translateX(2px);
}

/* Newsletter */
.footer-form{
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  margin-top: 10px;
}
.footer-input{
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.05);
  padding: 12px 12px;
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: 13px;
  color: rgba(255,255,255,.92);
  outline: none;
}
.footer-input::placeholder{ color: rgba(255,255,255,.55); }
.footer-input:focus{
  border-color: rgba(255,106,61,.55);
  box-shadow: 0 0 0 4px rgba(255,106,61,.18);
}

.footer-btn{
  border: 0;
  border-radius: 14px;
  padding: 12px 14px;
  cursor: pointer;
  font-family: "Montserrat", system-ui, sans-serif;
  font-weight: 900;
  font-size: 12px;
  color: #0b1220;
  background: #ff6a3d;
  transition: transform .2s ease, opacity .2s ease;
}
.footer-btn:hover{ transform: translateY(-1px); opacity: .95; }

.footer-mini{
  margin-top: 14px;
  display: grid;
  gap: 8px;
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: 13px;
  color: rgba(255,255,255,.70);
}
.footer-mini a{
  color: rgba(255,255,255,.90);
  text-decoration: none;
  font-weight: 800;
}
.footer-mini a:hover{ text-decoration: underline; }

/* Bottom bar */
.site-footer__bottom{
  margin-top: 18px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 16px 6px 0;
  border-top: 1px solid rgba(255,255,255,.08);
  color: rgba(255,255,255,.62);
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: 12.5px;
}

.site-footer__legal{
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.site-footer__legal a{
  color: rgba(255,255,255,.70);
  text-decoration: none;
  font-weight: 800;
}
.site-footer__legal a:hover{ color: rgba(255,255,255,.95); text-decoration: underline; }

/* Responsive */
@media (max-width: 1000px){
  .site-footer__grid{
    grid-template-columns: 1fr 1fr;
  }
}
@media (max-width: 820px){
  .site-footer__promo{
    flex-direction: column;
    align-items: flex-start;
  }
}
@media (max-width: 620px){
  .site-footer__grid{
    grid-template-columns: 1fr;
    padding: 16px;
  }
  .footer-form{
    grid-template-columns: 1fr;
  }
  .site-footer__bottom{
    flex-direction: column;
    align-items: flex-start;
  }
}

/* ===== Shop Page ===== */
.shop-page{
  background: #f3f5f9;
  color: #0f172a;
}

.shop-shell{
  padding: 26px 16px 70px;
}
.shop-layout{
  max-width: 1180px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 22px;
}
.shop-sidebar{
  display: grid;
  gap: 18px;
}
.shop-panel{
  background: #fff;
  border: 1px solid rgba(15,23,42,.08);
  border-radius: 18px;
  padding: 18px;
  box-shadow: 0 16px 30px rgba(15,23,42,.08);
}
.shop-panel__title{
  margin: 0 0 14px;
  font-family: "Playfair Display", serif;
  font-size: 18px;
  color: #0f172a;
}
.shop-panel__head{
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
}
.shop-panel__label{
  margin: 0;
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: #0f172a;
}
.shop-panel__toggle{
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: 16px;
  color: rgba(15,23,42,.6);
}
.shop-search{
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(15,23,42,.12);
  background: #f8fafc;
}
.shop-search__input{
  border: 0;
  background: transparent;
  outline: none;
  flex: 1;
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: 12px;
  color: #0f172a;
}
.shop-search__btn{
  border: 0;
  background: transparent;
  cursor: pointer;
  color: rgba(15,23,42,.7);
}
.shop-list{
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 10px;
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: 12px;
  color: rgba(15,23,42,.8);
}
.shop-list label{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  cursor: pointer;
}
.shop-list input{
  margin-right: 8px;
}
.shop-list span{
  color: rgba(15,23,42,.5);
}
.shop-list--ratings label{
  justify-content: flex-start;
}
.shop-list--ratings .stars{
  margin: 0 8px 0 4px;
  color: #f59e0b;
  font-size: 12px;
}
.shop-price{
  display: grid;
  gap: 10px;
}
.shop-price__range{
  width: 100%;
}
.shop-price__row{
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: 12px;
  color: rgba(15,23,42,.7);
}
.shop-price__btn{
  border: 1px solid rgba(15,23,42,.12);
  background: #fff;
  border-radius: 999px;
  padding: 6px 12px;
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
}
.shop-tags{
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.tag{
  border: 1px solid rgba(15,23,42,.12);
  background: #fff;
  padding: 6px 10px;
  border-radius: 999px;
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: 11px;
  cursor: pointer;
  color: rgba(15,23,42,.7);
}
.shop-promo{
  display: grid;
  grid-template-columns: 40px 1fr;
  align-items: center;
  gap: 12px;
}
.shop-promo__icon{
  width: 40px;
  height: 40px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  background: rgba(14,116,170,.12);
  color: #0e7490;
  font-weight: 700;
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: 12px;
}
.shop-promo__title{
  font-family: "Montserrat", system-ui, sans-serif;
  font-weight: 700;
  font-size: 13px;
}
.shop-promo__text{
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: 12px;
  color: rgba(15,23,42,.6);
}
.shop-main{
  display: grid;
  gap: 16px;
}
.shop-pagination{
  display: flex;
  justify-content: center;
}
.shop-pagination ul{
  list-style: none;
  display: inline-flex;
  gap: 8px;
  padding: 0;
  margin: 12px 0 0;
}
.shop-pagination a,
.shop-pagination span{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 36px;
  height: 36px;
  padding: 0 10px;
  border-radius: 999px;
  border: 1px solid rgba(15,23,42,.12);
  background: #fff;
  color: #0f172a;
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: 12px;
  text-decoration: none;
}
.shop-pagination .current{
  background: #0f172a;
  color: #fff;
  border-color: #0f172a;
}
.shop-toolbar{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}
.shop-results{
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: 12px;
  color: rgba(15,23,42,.6);
}
.shop-sort{
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.shop-sort__label{
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: 12px;
  color: rgba(15,23,42,.6);
}
.shop-sort__select{
  border-radius: 10px;
  border: 1px solid rgba(15,23,42,.12);
  background: #fff;
  color: rgba(15,23,42,.8);
  padding: 8px 12px;
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: 12px;
}
.shop-grid{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}
.shop-card{
  background: #fff;
  border: 1px solid rgba(15,23,42,.08);
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 18px 30px rgba(15,23,42,.08);
  display: flex;
  flex-direction: column;
  height: 100%;
}
.shop-card__img{
  background: #f1f5f9;
  display: grid;
  place-items: center;
  padding: 18px;
  aspect-ratio: 4 / 3;
  flex: 0 0 auto;
}
.shop-card__img img{
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.shop-card__imgPlaceholder{
  width: 100%;
  height: 100%;
  min-height: 180px;
  display: grid;
  place-items: center;
  color: rgba(15,23,42,.45);
  font-family: "Montserrat", system-ui, sans-serif;
  font-weight: 700;
  font-size: 12px;
  border: 1px dashed rgba(15,23,42,.18);
  border-radius: 14px;
}
.shop-card__body{
  padding: 16px 18px 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  text-align: center;
  flex: 1 1 auto;
}
.shop-card__title{
  margin: 0;
  font-family: "Montserrat", system-ui, sans-serif;
  font-weight: 700;
  font-size: 16px;
  color: #0f172a;
}
.shop-card__desc{
  margin: 0;
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: 12px;
  line-height: 1.6;
  color: rgba(15,23,42,.6);
  flex: 1 1 auto;
}
.shop-card__btn{
  justify-self: center;
  border: 0;
  border-radius: 999px;
  padding: 10px 18px;
  cursor: pointer;
  font-family: "Montserrat", system-ui, sans-serif;
  font-weight: 700;
  font-size: 12px;
  color: #fff;
  background: #0e7490;
  transition: transform .2s ease, opacity .2s ease;
  margin-top: auto;
  align-self: center;
}
.shop-card__btn:hover{ transform: translateY(-1px); opacity: .95; }

@media (max-width: 1100px){
  .shop-layout{
    grid-template-columns: 260px 1fr;
  }
  .shop-grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 860px){
  .shop-layout{
    grid-template-columns: 1fr;
  }
  .shop-sidebar{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .shop-panel{
    padding: 16px;
  }
}
@media (max-width: 620px){
  .shop-shell{
    padding: 20px 14px 60px;
  }
  .shop-sidebar{
    grid-template-columns: 1fr;
  }
  .shop-grid{
    grid-template-columns: 1fr;
  }
  .shop-toolbar{
    flex-direction: column;
    align-items: flex-start;
  }
}

/* ===== Search + Archive (Light theme) ===== */
body.page-template-page-blog,
body.page-template-page-blog-php,
.search,
.archive,
.page-template-page-blog,
.category,
.tag,
.author,
.error404,
.single{
  background: #f3f5f9;
  color: #0f172a;
}
.search .topbar,
.archive .topbar,
.page-template-page-blog .topbar,
.category .topbar,
.tag .topbar,
.author .topbar,
.error404 .topbar,
.single .topbar{
  position: sticky;
  top: 0;
  z-index: 10;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(15,23,42,.08);
}
.search .nav__link,
.archive .nav__link,
.page-template-page-blog .nav__link,
.category .nav__link,
.tag .nav__link,
.author .nav__link,
.error404 .nav__link,
.single .nav__link{
  color: #1f2937;
}
.search .nav__link:hover,
.archive .nav__link:hover,
.page-template-page-blog .nav__link:hover,
.category .nav__link:hover,
.tag .nav__link:hover,
.author .nav__link:hover,
.error404 .nav__link:hover,
.single .nav__link:hover{
  background: rgba(15,23,42,.06);
  color: #0f172a;
}
.search .nav__link.is-active,
.archive .nav__link.is-active,
.page-template-page-blog .nav__link.is-active,
.category .nav__link.is-active,
.tag .nav__link.is-active,
.author .nav__link.is-active,
.error404 .nav__link.is-active,
.single .nav__link.is-active{
  background: rgba(15,23,42,.08);
  color: #0f172a;
  border-color: rgba(15,23,42,.12);
}
.search .topbar__search,
.archive .topbar__search,
.page-template-page-blog .topbar__search,
.category .topbar__search,
.tag .topbar__search,
.author .topbar__search,
.error404 .topbar__search,
.single .topbar__search{
  border-color: rgba(15,23,42,.12);
  background: rgba(15,23,42,.04);
}
.search .topbar__searchInput,
.archive .topbar__searchInput,
.page-template-page-blog .topbar__searchInput,
.category .topbar__searchInput,
.tag .topbar__searchInput,
.author .topbar__searchInput,
.error404 .topbar__searchInput,
.single .topbar__searchInput{
  color: #0f172a;
}
.search .topbar__searchInput::placeholder,
.archive .topbar__searchInput::placeholder,
.page-template-page-blog .topbar__searchInput::placeholder,
.category .topbar__searchInput::placeholder,
.tag .topbar__searchInput::placeholder,
.author .topbar__searchInput::placeholder,
.error404 .topbar__searchInput::placeholder,
.single .topbar__searchInput::placeholder{
  color: rgba(15,23,42,.5);
}
.search .topbar__searchBtn,
.archive .topbar__searchBtn,
.page-template-page-blog .topbar__searchBtn,
.category .topbar__searchBtn,
.tag .topbar__searchBtn,
.author .topbar__searchBtn,
.error404 .topbar__searchBtn,
.single .topbar__searchBtn{
  color: rgba(15,23,42,.7);
}
.search-shell{
  max-width: 1180px;
  margin: 0 auto;
  padding: 28px 16px 70px;
  display: grid;
  gap: 16px;
}
.search-head{
  display: grid;
  gap: 6px;
}
.search-title{
  margin: 0;
  font-family: "Playfair Display", serif;
  font-weight: 700;
  font-size: clamp(28px, 3vw, 40px);
  color: #0f172a;
}
.search-subtitle{
  margin: 0;
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: 13px;
  color: rgba(15,23,42,.6);
}
.search-empty{
  margin: 10px 0 0;
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: 13px;
  color: rgba(15,23,42,.6);
}























/* ===== Shop By Category ===== */
.categories{
  padding: clamp(48px, 6vw, 88px) 16px;
  background: #ffffff;
}

.categories__container{
  max-width: 1100px;
  margin: 0 auto;
}

.categories__head{
  text-align: center;
  margin-bottom: 22px;
}

.categories__title{
  margin: 0;
  font-family: "Playfair Display", serif;
  font-weight: 700;
  letter-spacing: .2px;
  font-size: clamp(26px, 3.4vw, 42px);
  color: #2b2f36;
}

/* Grid row like your image */
.categories__grid{
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 18px;
  align-items: start;
}

/* Card */
.cat-card{
  text-decoration: none;
  color: inherit;
  display: grid;
  gap: 12px;
}

.cat-card__img{
  border-radius: 20px;
  background: #f6f7f9;
  border: 1px solid rgba(17, 24, 39, .06);
  box-shadow: 0 18px 30px rgba(15, 23, 42, .08);
  overflow: hidden;
  aspect-ratio: 16 / 8; /* wide card feel */
  display: grid;
  place-items: center;
}

.cat-card__img img{
  width: 100%;
  height: 100%;
  object-fit: contain; /* keeps product centered like the example */
  padding: 18px;
  transform: translateZ(0) scale(1);
  transition: transform .25s ease;
}

.cat-card__label{
  text-align: center;
  font-family: "Montserrat", system-ui, sans-serif;
  font-weight: 800;
  font-size: 13px;
  color: #0f172a;
}

.cat-card:hover .cat-card__img img{
  transform: scale(1.04);
}

/* Responsive: become horizontal scroll (looks great on mobile) */
@media (max-width: 1100px){
  .categories__grid{
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 760px){
  .categories__grid{
    grid-auto-flow: column;
    grid-auto-columns: minmax(220px, 1fr);
    grid-template-columns: none;
    overflow-x: auto;
    padding: 4px 2px 14px;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .categories__grid::-webkit-scrollbar{ display:none; }
  .cat-card{ scroll-snap-align: start; }
}
















/* ===== Our Solutions (mosaic) ===== */
.solutions{
  padding: clamp(48px, 6vw, 88px) 16px;
  background: #ffffff;
}

.solutions__container{
  max-width: 1100px;
  margin: 0 auto;
}

.solutions__head{
  text-align: center;
  margin-bottom: 22px;
}

.solutions__title{
  margin: 0 0 8px;
  font-family: "Playfair Display", serif;
  font-weight: 700;
  letter-spacing: .2px;
  font-size: clamp(28px, 3.6vw, 44px);
  color: #2b2f36;
}

.solutions__subtitle{
  margin: 0;
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: clamp(14px, 1.8vw, 18px);
  color: #6b7280;
  line-height: 1.6;
}

.solutions__subtitle::after{
  content: "";
  display: block;
  width: 74px;
  height: 3px;
  margin: 14px auto 0;
  background: #ff6a3d;
  border-radius: 999px;
  opacity: .85;
}

/* Grid like screenshot */
.solutions__grid{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

/* Cards */
.sol-card, .sol-banner{
  border-radius: 22px;
  overflow: hidden;
  border: 1px solid rgba(17, 24, 39, .08);
  box-shadow: 0 18px 30px rgba(15, 23, 42, .08);
  background: #f6f7f9;
}

.sol-card__link, .sol-banner__link{
  display: block;
  position: relative;
  height: 100%;
  text-decoration: none;
  color: #fff;
}

.sol-card{
  min-height: 250px;
}

.sol-card__img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transform: scale(1.02);
  transition: transform .45s ease;
}

.sol-card__overlay{
  position: absolute;
  inset: 0;
  background:
    radial-gradient(900px 400px at 30% 0%, rgba(0,0,0,.10), transparent 55%),
    linear-gradient(to top, rgba(0,0,0,.55), rgba(0,0,0,.12));
}

.sol-card__content{
  position: absolute;
  inset: 18px;
  display: grid;
  align-content: start;
  gap: 10px;
}

.sol-card__content--center{
  text-align: center;
  align-content: center;
}

.sol-card__kicker{
  font-family: "Montserrat", system-ui, sans-serif;
  font-weight: 800;
  font-size: 11px;
  letter-spacing: .25em;
  text-transform: uppercase;
  opacity: .9;
}

.sol-card__h{
  margin: 0;
  font-family: "Montserrat", system-ui, sans-serif;
  font-weight: 900;
  font-size: 26px;
  line-height: 1.05;
  letter-spacing: -.02em;
  text-shadow: 0 10px 30px rgba(0,0,0,.25);
}

.sol-card__cta{
  margin-top: 6px;
  font-family: "Montserrat", system-ui, sans-serif;
  font-weight: 800;
  font-size: 12px;
  text-decoration: underline;
  text-underline-offset: 4px;
  opacity: .95;
}

/* Hover */
.sol-card:hover .sol-card__img,
.sol-banner:hover .sol-banner__img{
  transform: scale(1.07);
}

/* Banner */
.sol-banner{
  grid-column: 1 / -1;
  min-height: 290px;
}

.sol-banner__img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transform: scale(1.02);
  transition: transform .45s ease;
}

.sol-banner__overlay{
  position: absolute;
  inset: 0;
  background:
    radial-gradient(1000px 550px at 15% 10%, rgba(255,255,255,.14), transparent 60%),
    linear-gradient(to right, rgba(0,0,0,.55), rgba(0,0,0,.12));
}

.sol-banner__content{
  position: absolute;
  left: 20px;
  top: 50%;
  transform: translateY(-50%);
  max-width: 420px;
  display: grid;
  gap: 10px;
}

.sol-banner__kicker{
  font-family: "Montserrat", system-ui, sans-serif;
  font-weight: 800;
  font-size: 11px;
  letter-spacing: .25em;
  text-transform: uppercase;
  opacity: .9;
}

.sol-banner__h{
  margin: 0;
  font-family: "Montserrat", system-ui, sans-serif;
  font-weight: 900;
  font-size: 38px;
  line-height: 1.02;
  letter-spacing: -.02em;
  text-shadow: 0 10px 30px rgba(0,0,0,.25);
}

.sol-banner__p{
  margin: 0;
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: 13px;
  line-height: 1.7;
  color: rgba(255,255,255,.85);
}

.sol-banner__btn{
  justify-self: start;
  margin-top: 4px;
  display: inline-flex;
  align-items: center;
  padding: 10px 14px;
  border-radius: 999px;
  font-family: "Montserrat", system-ui, sans-serif;
  font-weight: 900;
  font-size: 12px;
  color: #111827;
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(255,255,255,.20);
  box-shadow: 0 18px 30px rgba(0,0,0,.18);
}

/* Responsive */
@media (max-width: 980px){
  .solutions__grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .sol-banner{ grid-column: 1 / -1; }
}

@media (max-width: 620px){
  .solutions__grid{ grid-template-columns: 1fr; }
  .sol-card{ min-height: 220px; }
  .sol-banner__content{
    left: 16px;
    right: 16px;
    max-width: none;
  }
  .sol-banner__h{ font-size: 30px; }
}

/* ===== Single Product ===== */
.single-unv2_product{
  background: #f3f5f9;
  color: #0f172a;
}
.single-unv2_product .topbar{
  position: sticky;
  top: 0;
  z-index: 10;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(15,23,42,.08);
}
.single-unv2_product .nav__link{
  color: #1f2937;
}
.single-unv2_product .nav__link:hover{
  background: rgba(15,23,42,.06);
  color: #0f172a;
}
.single-unv2_product .nav__link.is-active{
  background: rgba(15,23,42,.08);
  color: #0f172a;
  border-color: rgba(15,23,42,.12);
}
.single-unv2_product .topbar__cta{
  background: #0f172a;
  color: #fff;
  border-color: rgba(15,23,42,.2);
}
.product-single{
  max-width: 1100px;
  margin: 0 auto;
  padding: 34px 16px 80px;
  display: grid;
  gap: 28px;
}
.product-single__row{
  background: #fff;
  border: 1px solid rgba(15,23,42,.08);
  border-radius: 22px;
  padding: 24px;
  box-shadow: 0 18px 30px rgba(15,23,42,.08);
  display: grid;
  gap: 24px;
}
.product-single__row--top{
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
  align-items: start;
}
.product-single__media{
  background: #f1f5f9;
  border-radius: 18px;
  padding: 18px;
  display: grid;
  place-items: center;
  min-height: 320px;
}
.product-single__image{
  width: 100%;
  height: auto;
  object-fit: contain;
  border-radius: 14px;
}
.product-single__image--placeholder{
  width: 100%;
  height: 100%;
  min-height: 280px;
  display: grid;
  place-items: center;
  color: rgba(15,23,42,.45);
  font-family: "Montserrat", system-ui, sans-serif;
  font-weight: 700;
  font-size: 12px;
  border: 1px dashed rgba(15,23,42,.2);
  border-radius: 14px;
}
.product-single__kicker{
  margin: 0 0 8px;
  font-family: "Montserrat", system-ui, sans-serif;
  font-weight: 800;
  font-size: 11px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: rgba(15,23,42,.6);
}
.product-single__title{
  margin: 0 0 10px;
  font-family: "Playfair Display", serif;
  font-weight: 700;
  font-size: clamp(26px, 3vw, 40px);
  color: #0f172a;
}
.product-single__excerpt{
  margin: 0 0 16px;
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: 14px;
  line-height: 1.7;
  color: rgba(15,23,42,.7);
}
.product-single__meta{
  display: grid;
  gap: 10px;
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: 13px;
  color: rgba(15,23,42,.8);
}
.product-single__metaItem strong{
  color: #0f172a;
}
.product-single__subtitle{
  margin: 0 0 10px;
  font-family: "Montserrat", system-ui, sans-serif;
  font-weight: 800;
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: .14em;
  color: rgba(15,23,42,.7);
}
.product-single__content{
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: 14px;
  line-height: 1.8;
  color: rgba(15,23,42,.75);
}
.product-single__additional{
  background: #f8fafc;
  border: 1px solid rgba(15,23,42,.08);
  border-radius: 18px;
  padding: 18px;
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: 13px;
  line-height: 1.7;
  color: rgba(15,23,42,.7);
}

@media (max-width: 960px){
  .product-single__row--top,
  .product-single__row--bottom{
    grid-template-columns: 1fr;
  }
}

/* ===== Team Section ===== */
.team{
  padding: clamp(48px, 6vw, 88px) 16px;
  background: #ffffff;
}

.team__container{
  max-width: 1100px;
  margin: 0 auto;
}

.team__head{
  text-align: center;
  margin-bottom: 26px;
}

.team__title{
  margin: 0 0 8px;
  font-family: "Playfair Display", serif;
  font-weight: 700;
  letter-spacing: .2px;
  font-size: clamp(28px, 3.6vw, 44px);
  color: #2b2f36;
}

.team__subtitle{
  margin: 0;
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: clamp(14px, 1.8vw, 18px);
  color: #6b7280;
  line-height: 1.6;
}

.team__subtitle::after{
  content: "";
  display: block;
  width: 74px;
  height: 3px;
  margin: 14px auto 0;
  background: #ff6a3d;
  border-radius: 999px;
  opacity: .85;
}

.team__grid{
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.team-card{
  background: #fff;
  border: 1px solid rgba(17, 24, 39, .08);
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 18px 30px rgba(15, 23, 42, .08);
  display: grid;
  grid-template-rows: auto 1fr;
}

.team-card__media{
  background: #f3f4f6;
  height: clamp(220px, 26vw, 260px);
  display: grid;
  place-items: center;
}

.team-card__img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.team-card__img--placeholder{
  width: 100%;
  height: 100%;
  display: grid;
  place-items: center;
  font-family: "Montserrat", system-ui, sans-serif;
  font-weight: 700;
  font-size: 12px;
  color: rgba(15, 23, 42, .45);
  border: 1px dashed rgba(15, 23, 42, .16);
  border-radius: 12px;
  margin: 12px;
}

.team-card__body{
  padding: 16px 16px 20px;
  text-align: center;
  display: grid;
  gap: 6px;
}

.team-card__name{
  margin: 0;
  font-family: "Montserrat", system-ui, sans-serif;
  font-weight: 800;
  font-size: 16px;
  color: #0f172a;
}

.team-card__role{
  margin: 0;
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: 12px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(15, 23, 42, .55);
}

.team-card__bio{
  margin: 4px 0 0;
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: 12.5px;
  line-height: 1.6;
  color: rgba(15, 23, 42, .65);
}

@media (max-width: 1000px){
  .team__grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 560px){
  .team__grid{ grid-template-columns: 1fr; }
}
