:root{
  --bg: #f6f8fb;
  --surface: #ffffff;
  --text: #0f172a;
  --muted: #64748b;
  --border: rgba(15, 23, 42, .10);
  --shadow: 0 18px 45px rgba(2, 6, 23, .08);
  --shadow-sm: 0 10px 26px rgba(2, 6, 23, .08);
  --accent: #1d4ed8;
  --accent-2: #16a34a;
  --radius: 16px;
}

html{
  scroll-behavior: smooth;
}

body{
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background: var(--bg);
  color: var(--text);
}

.contact-page{
  background: var(--bg);
}

main > section + section{
  margin-top: clamp(12px, 1.8vw, 22px);
}

.accordion{
  --bs-accordion-border-radius: 12px;
  --bs-accordion-inner-border-radius: 12px;
}
.accordion-item + .accordion-item{
  margin-top: 12px;
  border-top: 1px solid rgba(15, 23, 42, .10);
}

.skip-link{
  position: absolute;
  left: -999px;
  top: 12px;
  background: var(--surface);
  border: 1px solid var(--border);
  padding: 10px 12px;
  border-radius: 10px;
  z-index: 9999;
}
.skip-link:focus{
  left: 12px;
}

.navbar .nav-link{
  font-weight: 500;
  color: #0b1220;
}
.navbar .nav-link:hover{
  color: var(--accent);
}
.navbar .nav-link.active{
  color: var(--accent);
}

.brand-mark{
  width: 28px;
  height: 28px;
  border-radius: 10px;
  background: radial-gradient(120% 120% at 10% 10%, #60a5fa 0%, var(--accent) 50%, #0ea5e9 100%);
  box-shadow: 0 10px 18px rgba(29, 78, 216, .25);
}
.site-logo{
  width: 100px;
  height: 75px;
  object-fit: contain;
  display: block;
}
.site-logo--footer{
  width: 100px;
  height: 100px;
}

.btn{
  --bs-btn-padding-y: .7rem;
  --bs-btn-padding-x: 1.15rem;
  --bs-btn-font-size: 1rem;
  --bs-btn-border-radius: 14px;
}
.btn-sm{
  --bs-btn-padding-y: .55rem;
  --bs-btn-padding-x: 1rem;
  --bs-btn-font-size: .95rem;
  --bs-btn-border-radius: 12px;
}

.btn-primary{
  --bs-btn-bg: var(--accent);
  --bs-btn-border-color: var(--accent);
  --bs-btn-hover-bg: #1b46c4;
  --bs-btn-hover-border-color: #1b46c4;
  --bs-btn-active-bg: #163aa4;
  --bs-btn-active-border-color: #163aa4;
  --bs-btn-focus-shadow-rgb: 29, 78, 216;
}
.btn-outline-primary{
  --bs-btn-color: var(--accent);
  --bs-btn-border-color: rgba(29, 78, 216, .35);
  --bs-btn-hover-bg: var(--accent);
  --bs-btn-hover-border-color: var(--accent);
}

.section-pad{
  padding: clamp(22px, 3vw, 20px) 0;
}
.section-alt{
  background: linear-gradient(180deg, #f9fbff, #f6f8fb);
  border-top: 1px solid rgba(15, 23, 42, .06);
  border-bottom: 1px solid rgba(15, 23, 42, .06);
}
.section-head{
  margin-bottom: 10px;
}
.section-title{
  font-size: clamp(22px, 2.2vw, 34px);
  line-height: 1.15;
  letter-spacing: -0.02em;
  margin-bottom: 6px;
}
.section-subtitle{
  color: var(--muted);
  margin: 0;
}

.page-hero{
  padding: clamp(22px, 3vw, 42px) 0;
  background: linear-gradient(180deg, rgba(29, 78, 216, .09), rgba(246, 248, 251, 0));
  border-bottom: 1px solid rgba(15, 23, 42, .06);
}
.contact-page .page-hero{
  position: relative;
  overflow: hidden;
  background: none;
}
.contact-page .page-hero::before{
  content: "";
  position: absolute;
  inset: 0;
  background-image: var(--page-hero-bg, url("../images/hero/hero-section-banner.webp"));
  background-size: cover;
  background-position: center;
  transform: scale(1.02);
  filter: saturate(1.02);
}
.contact-page .page-hero::after{
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(246, 248, 251, .92) 0%, rgba(246, 248, 251, .82) 52%, rgba(246, 248, 251, .72) 100%);
}
.contact-page .page-hero > .container{
  position: relative;
  z-index: 1;
}
.residential-page{
  background: var(--bg);
}
.residential-page .page-hero{
  position: relative;
  overflow: hidden;
  background: none;
  height: 400px;
  display: grid;
  align-items: center;
  padding: 0;
}
.residential-page .page-hero::before{
  content: "";
  position: absolute;
  inset: 0;
  background-image: var(--page-hero-bg, url("../images/hero/hero-section-banner.webp"));
  background-size: cover;
  background-position: center;
  transform: scale(1.02);
  filter: saturate(1.02);
}
.residential-page .page-hero::after{
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(246, 248, 251, .92) 0%, rgba(246, 248, 251, .82) 52%, rgba(246, 248, 251, .72) 100%);
}
.residential-page .page-hero > .container{
  position: relative;
  z-index: 1;
  width: 100%;
}
.commercial-page{
  background: var(--bg);
}
.commercial-page .page-hero{
  position: relative;
  overflow: hidden;
  background: none;
  height: 400px;
  display: grid;
  align-items: center;
  padding: 0;
}
.commercial-page .page-hero::before{
  content: "";
  position: absolute;
  inset: 0;
  background-image: var(--page-hero-bg, url("../images/hero/hero-section-banner.webp"));
  background-size: cover;
  background-position: center;
  transform: scale(1.02);
  filter: saturate(1.02);
}
.commercial-page .page-hero::after{
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(246, 248, 251, .92) 0%, rgba(246, 248, 251, .82) 52%, rgba(246, 248, 251, .72) 100%);
}
.commercial-page .page-hero > .container{
  position: relative;
  z-index: 1;
  width: 100%;
}
.partners-page{
  background: var(--bg);
}
.partners-page .page-hero{
  position: relative;
  overflow: hidden;
  background: none;
  height: 400px;
  display: grid;
  align-items: center;
  padding: 0;
}
.partners-page .page-hero::before{
  content: "";
  position: absolute;
  inset: 0;
  background-image: var(--page-hero-bg, url("../images/hero/hero-section-banner.webp"));
  background-size: cover;
  background-position: center;
  transform: scale(1.02);
  filter: saturate(1.02);
}

.category-page{
  background: var(--bg);
}
.category-page .page-hero{
  position: relative;
  overflow: hidden;
  background: none;
  height: 400px;
  display: grid;
  align-items: center;
  padding: 0;
}
.category-page .page-hero::before{
  content: "";
  position: absolute;
  inset: 0;
  background-image: var(--page-hero-bg, url("../images/hero/hero-section-banner.webp"));
  background-size: cover;
  background-position: center;
  transform: scale(1.02);
  filter: saturate(1.02);
}
.category-page .page-hero::after{
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(246, 248, 251, .92) 0%, rgba(246, 248, 251, .82) 52%, rgba(246, 248, 251, .72) 100%);
}
.category-page .page-hero > .container{
  position: relative;
  z-index: 1;
  width: 100%;
}
.partners-page .page-hero::after{
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(246, 248, 251, .92) 0%, rgba(246, 248, 251, .82) 52%, rgba(246, 248, 251, .72) 100%);
}
.partners-page .page-hero > .container{
  position: relative;
  z-index: 1;
  width: 100%;
}
.partners-grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
.partner-tile{
  height: 92px;
  border-radius: 14px;
  border: 1px solid rgba(15, 23, 42, .08);
  background: rgba(255, 255, 255, .92);
  box-shadow: 0 10px 26px rgba(2, 6, 23, .06);
  display: grid;
  place-items: center;
  padding: 14px;
}
.partner-tile img{
  max-width: 100%;
  max-height: 60px;
  opacity: .9;
  transition: opacity .18s ease, filter .18s ease, transform .18s ease;
}
.partner-tile:hover img{
  opacity: 1;
  filter: grayscale(0);
  transform: translateY(-1px);
}
@media (min-width: 576px){
  .partners-grid{ grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (min-width: 768px){
  .partners-grid{ grid-template-columns: repeat(4, minmax(0, 1fr)); }
}
@media (min-width: 992px){
  .partners-grid{ grid-template-columns: repeat(6, minmax(0, 1fr)); }
}
.project-grid .project-card{
  width: 100%;
}
.about-page{
  background: var(--bg);
}
.about-hero{
  position: relative;
  padding: 56px 0;
  background: none;
  border-bottom: 1px solid rgba(15, 23, 42, .06);
}
.about-hero::before{
  content: "";
  position: absolute;
  inset: 0;
  background-image: var(--page-hero-bg, url("../images/hero/hero-section-banner.webp"));
  background-size: cover;
  background-position: center;
  filter: saturate(1.02);
  transform: scale(1.02);
}
.about-hero::after{
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(2, 6, 23, .70) 0%, rgba(2, 6, 23, .62) 50%, rgba(2, 6, 23, .78) 100%);
}
.about-hero .container{
  position: relative;
  z-index: 1;
}
.about-hero-inner{
  text-align: center;
  color: rgba(255, 255, 255, .92);
}
.about-hero-title{
  margin: 0 0 10px;
  font-weight: 900;
  letter-spacing: -0.03em;
  font-size: clamp(28px, 3.2vw, 44px);
}
.about-hero-title span{
  color: #ef4444;
}
.about-hero .crumbs{
  color: rgba(255, 255, 255, .75);
}
.about-hero .crumbs a:hover{
  color: #ffffff;
}
.about-media{
  position: relative;
  padding: 14px;
  border-radius: 18px;
  background: rgba(255, 255, 255, .9);
  border: 1px solid rgba(15, 23, 42, .08);
  box-shadow: 0 12px 32px rgba(2, 6, 23, .06);
}
.about-media-main{
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid rgba(15, 23, 42, .10);
}
.about-media-main img{
  width: 100%;
  height: 290px;
  object-fit: cover;
  display: block;
}
.about-media-float{
  position: absolute;
  left: 22px;
  bottom: -18px;
  width: min(52%, 260px);
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid rgba(15, 23, 42, .10);
  box-shadow: 0 16px 40px rgba(2, 6, 23, .16);
  background: #ffffff;
}
.about-media-float img{
  width: 100%;
  height: 180px;
  object-fit: cover;
  display: block;
}
.about-copy{
  padding-left: 6px;
}
.about-kicker{
  width: 44px;
  height: 3px;
  border-radius: 999px;
  background: #ef4444;
  margin-bottom: 10px;
}
.about-title{
  font-size: 22px;
  font-weight: 900;
  letter-spacing: -0.02em;
  margin: 0 0 10px;
}
.about-points{
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 10px;
}
.about-points li{
  position: relative;
  padding-left: 26px;
  color: rgba(15, 23, 42, .78);
  font-weight: 600;
}
.about-points li::before{
  content: "";
  position: absolute;
  left: 0;
  top: 2px;
  width: 16px;
  height: 16px;
  border-radius: 999px;
  background: rgba(239, 68, 68, .12);
  border: 1px solid rgba(239, 68, 68, .45);
}
.about-points li::after{
  content: "";
  position: absolute;
  left: 5px;
  top: 7px;
  width: 6px;
  height: 3px;
  border-left: 2px solid #ef4444;
  border-bottom: 2px solid #ef4444;
  transform: rotate(-45deg);
}
.about-card{
  background: #ffffff;
  border: 1px solid rgba(15, 23, 42, .08);
  border-radius: 16px;
  padding: 18px 16px;
  height: 100%;
  box-shadow: 0 10px 30px rgba(2, 6, 23, .06);
  text-align: center;
}
.about-card-icon{
  width: 44px;
  height: 44px;
  border-radius: 14px;
  background: rgba(239, 68, 68, .10);
  color: #ef4444;
  display: grid;
  place-items: center;
  margin: 0 auto 10px;
}
.about-card-icon svg{
  width: 22px;
  height: 22px;
}
.about-card-title{
  font-weight: 900;
  letter-spacing: -0.02em;
  margin-bottom: 6px;
}
.about-card-text{
  color: rgba(15, 23, 42, .70);
  font-size: 13px;
}
.about-hot{
  color: #ef4444;
}
.about-faq-panel{
  padding: 0;
  overflow: hidden;
}
.about-accordion .accordion-button{
  font-weight: 700;
  color: rgba(15, 23, 42, .86);
  padding-right: 56px;
}


.about-review{
  flex: 0 0 86%;
  scroll-snap-align: start;
  background: rgba(239, 68, 68, .06);
  border: 1px solid rgba(239, 68, 68, .12);
  border-radius: 18px;
  padding: 18px;
  box-shadow: 0 12px 32px rgba(2, 6, 23, .06);
}
.about-review-text{
  margin: 0 0 12px;
  color: rgba(15, 23, 42, .84);
  line-height: 1.7;
}
.about-review-by{
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: baseline;
}
@media (max-width: 991.98px){
  .about-media-main img{ height: 250px; }
  .about-media-float{ position: static; width: 100%; margin-top: 12px; }
  .about-media-float img{ height: 180px; }
}
.crumbs{
  display: flex;
  gap: 8px;
  align-items: center;
  color: rgba(15, 23, 42, .70);
  font-size: 13px;
  margin-bottom: 10px;
}
.crumbs a{
  color: inherit;
  text-decoration: none;
}
.crumbs a:hover{
  color: var(--accent);
}
.crumb-sep{
  opacity: .6;
}
.page-title{
  font-size: clamp(26px, 3vw, 44px);
  line-height: 1.05;
  letter-spacing: -0.03em;
}
.page-subtitle{
  color: rgba(15, 23, 42, .70);
}
.quote-card{
  border-color: rgba(29, 78, 216, .12);
}
.quote-text{
  color: rgba(15, 23, 42, .88);
  font-size: 15px;
  line-height: 1.65;
}
.map-frame{
  display: block;
  width: 100%;
  height: min(52vh, 520px);
  border: 0;
}
.contact-split .panel{
  border-radius: 12px;
}
.contact-info-card{
  padding: 22px;
}
.contact-block-head{
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 10px;
}
.contact-block-icon{
  width: 38px;
  height: 38px;
  border-radius: 12px;
  background: rgba(220, 38, 38, .10);
  color: #dc2626;
  display: grid;
  place-items: center;
  flex: 0 0 auto;
}
.contact-block-icon svg{
  width: 18px;
  height: 18px;
}
.contact-block-title{
  font-weight: 700;
  color: rgba(15, 23, 42, .92);
}
.contact-block-body{
  display: grid;
  gap: 8px;
  padding-left: 50px;
}
.contact-link{
  color: rgba(15, 23, 42, .80);
  text-decoration: none;
}
.contact-link:hover{
  color: #dc2626;
  text-decoration: underline;
}
.contact-support{
  color: rgba(15, 23, 42, .80);
}
.contact-text{
  color: rgba(15, 23, 42, .72);
}
.contact-divider{
  height: 1px;
  background: rgba(15, 23, 42, .10);
  margin: 16px 0;
}
.form-card{
  padding: 22px;
}
.form-card-title{
  font-size: 20px;
  font-weight: 800;
  letter-spacing: -0.02em;
  margin: 0 0 6px;
}
.form-card-subtitle{
  color: rgba(15, 23, 42, .68);
  font-size: 13px;
}
.btn-contact{
  --bs-btn-bg: #dc2626;
  --bs-btn-border-color: #dc2626;
  --bs-btn-hover-bg: #b91c1c;
  --bs-btn-hover-border-color: #b91c1c;
  --bs-btn-active-bg: #991b1b;
  --bs-btn-active-border-color: #991b1b;
  --bs-btn-color: #ffffff;
}

.property-hero{
  padding-bottom: clamp(16px, 2vw, 28px);
}
.property-meta{
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  color: rgba(15, 23, 42, .74);
  font-size: 13px;
}
.property-meta-item{
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.property-meta-item svg{
  width: 16px;
  height: 16px;
}
.property-price{
  font-weight: 900;
  letter-spacing: -0.02em;
  font-size: 22px;
  color: rgba(15, 23, 42, .92);
  margin-bottom: 8px;
}
.property-price-sub{
  font-weight: 700;
  font-size: 12px;
  color: rgba(15, 23, 42, .58);
}
.property-gallery{
  padding: 14px;
}
.property-detail .panel + .panel{
  margin-top: 14px;
}
.property-gallery-main{
  display: block;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid rgba(15, 23, 42, .10);
}
.property-gallery-main{
  cursor: zoom-in;
}
.property-gallery-main img{
  width: 100%;
  height: 330px;
  object-fit: cover;
  display: block;
}
.property-thumbs{
  display: grid;
  gap: 10px;
}
.property-thumb{
  display: block;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid rgba(15, 23, 42, .10);
}
.property-thumb.is-active{
  border-color: rgba(220, 38, 38, .55);
  box-shadow: 0 10px 22px rgba(220, 38, 38, .12);
}
.property-thumb img{
  width: 100%;
  height: 76px;
  object-fit: cover;
  display: block;
}
.property-table th{
  width: 22%;
  font-weight: 700;
  color: rgba(15, 23, 42, .82);
}
.property-table td{
  width: 28%;
  color: rgba(15, 23, 42, .70);
}
.spec-grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.spec-item{
  display: flex;
  gap: 12px;
  padding: 12px;
  border: 1px solid rgba(15, 23, 42, .08);
  border-radius: 14px;
  background: rgba(2, 6, 23, .01);
}
.spec-icon{
  width: 40px;
  height: 40px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  background: rgba(29, 78, 216, .10);
  color: var(--accent);
  flex: 0 0 auto;
}
.spec-icon svg{
  width: 20px;
  height: 20px;
}
.spec-label{
  font-size: 12px;
  color: rgba(15, 23, 42, .58);
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.spec-value{
  font-weight: 700;
  color: rgba(15, 23, 42, .86);
}
.floor-card{
  border: 1px solid rgba(15, 23, 42, .08);
  border-radius: 14px;
  overflow: hidden;
  background: #ffffff;
}
.floor-card img{
  width: 100%;
  height: 220px;
  object-fit: cover;
  display: block;
}
.video-card{
  position: relative;
  display: block;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid rgba(15, 23, 42, .10);
  background: #0b1220;
}
.video-card img{
  width: 100%;
  height: 170px;
  object-fit: cover;
  display: block;
  opacity: .92;
}
.video-play{
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  color: #ffffff;
  background: radial-gradient(circle at center, rgba(2, 6, 23, .2), rgba(2, 6, 23, .45));
}
.video-play svg{
  width: 54px;
  height: 54px;
}
.amenity-grid{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.amenity-pill{
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(15, 23, 42, .10);
  background: rgba(2, 6, 23, .02);
  font-weight: 700;
  font-size: 12px;
  color: rgba(15, 23, 42, .78);
}
.sidebar-sticky{
  position: sticky;
  top: 90px;
  display: grid;
  gap: 14px;
}
.sidebar-card{
  padding: 18px;
}
.sidebar-price{
  font-size: 18px;
  font-weight: 900;
  letter-spacing: -0.02em;
}
.sidebar-sub{
  font-size: 13px;
}
.sidebar-facts{
  display: grid;
  gap: 10px;
}
.sidebar-facts li{
  display: flex;
  justify-content: space-between;
  gap: 10px;
}
@media (max-width: 991.98px){
  .sidebar-sticky{ position: static; }
  .property-gallery-main img{ height: 260px; }
  .spec-grid{ grid-template-columns: 1fr; }
}

.lightbox{
  position: fixed;
  inset: 0;
  background: rgba(2, 6, 23, .84);
  display: none;
  align-items: center;
  justify-content: center;
  padding: 18px;
  z-index: 9999;
}
.lightbox.is-open{
  display: flex;
}
.lightbox-dialog{
  width: min(1120px, 100%);
  height: min(82vh, 720px);
  border-radius: 18px;
  background: rgba(255, 255, 255, .06);
  border: 1px solid rgba(255, 255, 255, .12);
  box-shadow: 0 28px 80px rgba(0, 0, 0, .35);
  overflow: hidden;
  position: relative;
}
.lightbox-toolbar{
  position: absolute;
  top: 10px;
  right: 10px;
  display: flex;
  gap: 10px;
  z-index: 2;
}
.lightbox-btn{
  width: 42px;
  height: 42px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, .18);
  background: rgba(15, 23, 42, .55);
  color: #ffffff;
  display: grid;
  place-items: center;
}
.lightbox-btn svg{
  width: 18px;
  height: 18px;
}
.lightbox-stage{
  width: 100%;
  height: 100%;
  position: relative;
  overflow: hidden;
  cursor: grab;
}
.lightbox-stage:active{
  cursor: grabbing;
}
.lightbox-img{
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  transform-origin: center;
  will-change: transform;
  max-width: none;
  user-select: none;
  -webkit-user-drag: none;
}

.hero{
  position: relative;
  min-height: min(75vh, 820px);
  display: grid;
  align-items: center;
  overflow: hidden;
  background: #020617;
}
.hero-bg{
  position: absolute;
  inset: 0;
  background-image: var(--hero-bg, url("../images/hero/hero-section-banner.webp"));
  background-size: cover;
  background-position: center;
  transform: scale(1.02);
  filter: saturate(1.02);
}
.hero-overlay{
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(2, 6, 23, .66) 0%, rgba(2, 6, 23, .55) 40%, rgba(2, 6, 23, .72) 100%);
}

.hero-card{
  background: rgba(255, 255, 255, .92);
  border: 1px solid rgba(255, 255, 255, .52);
  border-radius: clamp(16px, 2vw, 22px);
  box-shadow: 0 26px 70px rgba(2, 6, 23, .32);
  padding: clamp(18px, 3vw, 32px);
  backdrop-filter: blur(10px);
}

.hero-kicker{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: rgba(15, 23, 42, .75);
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
  font-size: 12px;
  margin: 0 0 10px;
}
.hero-kicker::before{
  content: "";
  width: 34px;
  height: 2px;
  background: linear-gradient(90deg, var(--accent), var(--accent-2));
  border-radius: 10px;
}
.hero-title{
  font-size: clamp(26px, 3vw, 40px);
  line-height: 1.05;
  letter-spacing: -0.03em;
  margin: 0 0 10px;
}
.hero-subtitle{
  color: rgba(15, 23, 42, .72);
  font-size: 15px;
}

.hero-categories{
  display: flex;
  gap: 10px;
  justify-content: center;
  flex-wrap: wrap;
}
.chip{
  text-decoration: none;
  color: rgba(15, 23, 42, .82);
  background: rgba(2, 6, 23, .04);
  border: 1px solid rgba(2, 6, 23, .06);
  padding: 8px 12px;
  border-radius: 999px;
  font-weight: 600;
  font-size: 13px;
  transition: transform .18s ease, background .18s ease, border-color .18s ease;
}
.chip:hover{
  transform: translateY(-1px);
  background: rgba(29, 78, 216, .08);
  border-color: rgba(29, 78, 216, .18);
  color: var(--accent);
}

.searchbar .form-control,
.searchbar .form-select{
  border-radius: 12px;
  border-color: rgba(15, 23, 42, .14);
}
.searchbar .form-control:focus,
.searchbar .form-select:focus{
  border-color: rgba(29, 78, 216, .42);
  box-shadow: 0 0 0 .25rem rgba(29, 78, 216, .12);
}

.feature-card{
  background: var(--surface);
  border: 1px solid rgba(15, 23, 42, .08);
  border-radius: var(--radius);
  padding: 18px 16px;
  height: 100%;
  box-shadow: 0 10px 30px rgba(2, 6, 23, .06);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.feature-card:hover{
  transform: translateY(-3px);
  box-shadow: var(--shadow-sm);
  border-color: rgba(29, 78, 216, .18);
}
.feature-icon{
  width: 44px;
  height: 44px;
  border-radius: 14px;
  background: rgba(29, 78, 216, .08);
  color: var(--accent);
  display: grid;
  place-items: center;
  margin-bottom: 10px;
}
.feature-icon svg{
  width: 22px;
  height: 22px;
}
.feature-icon img{
  width: 22px;
  height: 22px;
  object-fit: contain;
}

.pill{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(29, 78, 216, .10);
  color: var(--accent);
  border: 1px solid rgba(29, 78, 216, .18);
  padding: 6px 10px;
  border-radius: 999px;
  font-weight: 600;
  font-size: 12px;
}

.media-frame{
  border-radius: 22px;
  overflow: hidden;
  border: 1px solid rgba(15, 23, 42, .08);
  box-shadow: var(--shadow-sm);
  background: var(--surface);
}
.media-frame img{
  width: 100%;
  height: auto;
  display: block;
}

.reel-controls{
  display: flex;
  gap: 8px;
}
.reel-btn{
  border-radius: 999px;
}
.reel-btn--icon{
  width: 48px;
  height: 48px;
  padding: 0;
  display: inline-grid;
  place-items: center;
}
.reel-btn--icon svg{
  width: 20px;
  height: 20px;
}

.reel-shell{
  position: relative;
  --reel-pad-x: 56px;
  --reel-btn-shift: 24px;
}
.reel-controls--mid{
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  padding: 0 var(--reel-pad-x, 8px);
  transform: translateY(-50%);
  align-items: center;
  justify-content: space-between;
  z-index: 2;
  pointer-events: none;
}
.reel-controls--mid .reel-btn:first-child{
  transform: translateX(calc(-1 * var(--reel-btn-shift)));
}
.reel-controls--mid .reel-btn:last-child{
  transform: translateX(var(--reel-btn-shift));
}
.reel-controls--mid .reel-btn{
  pointer-events: auto;
  background: rgba(255, 255, 255, .92);
  border: 1px solid rgba(15, 23, 42, .12);
  box-shadow: 0 10px 24px rgba(2, 6, 23, .12);
  backdrop-filter: blur(8px);
}
@media (max-width: 575.98px){
  .reel-shell{
    --reel-pad-x: 42px;
    --reel-btn-shift: 16px;
  }
}

.reel{
  display: flex;
  gap: 14px;
  overflow-x: auto;
  padding: 10px var(--reel-pad-x, 2px) 14px;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.reel::-webkit-scrollbar{
  display: none;
}

.project-card{
  flex: 0 0 86%;
  scroll-snap-align: start;
  background: var(--surface);
  border: 1px solid rgba(15, 23, 42, .08);
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 12px 32px rgba(2, 6, 23, .06);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.project-card:hover{
  transform: translateY(-3px);
  box-shadow: var(--shadow-sm);
  border-color: rgba(29, 78, 216, .16);
}
.project-card--grid{
  flex: 1 1 auto;
}
.project-img{
  width: 100%;
  height: 190px;
  object-fit: cover;
  display: block;
}
.project-body{
  padding: 14px 14px 16px;
}
.project-title{
  font-size: 16px;
  font-weight: 700;
  margin: 0 0 6px;
  letter-spacing: -0.02em;
}
.project-meta{
  color: var(--muted);
  font-size: 13px;
  margin: 0 0 10px;
}
.project-price{
  font-weight: 700;
  color: #0b1220;
  font-size: 13px;
}

.testimonial-card{
  flex: 0 0 86%;
  scroll-snap-align: start;
  background: var(--surface);
  border: 1px solid rgba(15, 23, 42, .08);
  border-radius: 18px;
  padding: 18px;
  box-shadow: 0 12px 32px rgba(2, 6, 23, .06);
}
.avatar{
  width: 48px;
  height: 48px;
  border-radius: 999px;
  border: 1px solid rgba(15, 23, 42, .10);
  background: rgba(2, 6, 23, .02);
}
.stars{
  font-size: 12px;
  letter-spacing: .08em;
  color: #f59e0b;
}

.blog-card{
  flex: 0 0 86%;
  scroll-snap-align: start;
  background: var(--surface);
  border: 1px solid rgba(15, 23, 42, .08);
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 12px 32px rgba(2, 6, 23, .06);
}
.blog-img{
  width: 100%;
  height: 180px;
  object-fit: cover;
  display: block;
}
.blog-body{
  padding: 14px 14px 16px;
}
.blog-title{
  font-size: 15px;
  font-weight: 800;
  margin: 0 0 8px;
  letter-spacing: -0.02em;
}
.blog-excerpt{
  color: var(--muted);
  font-size: 13px;
  margin: 0 0 12px;
}

.panel{
  background: var(--surface);
  border: 1px solid rgba(15, 23, 42, .08);
  border-radius: 18px;
  padding: 18px;
  box-shadow: 0 12px 32px rgba(2, 6, 23, .06);
}
.panel--soft{
  background: linear-gradient(180deg, rgba(29, 78, 216, .06), rgba(22, 163, 74, .05));
}
.contact-list{
  display: grid;
  gap: 14px;
}
.contact-item{
  display: flex;
  gap: 12px;
  align-items: flex-start;
}
.contact-icon{
  width: 40px;
  height: 40px;
  border-radius: 14px;
  background: rgba(29, 78, 216, .10);
  color: var(--accent);
  display: grid;
  place-items: center;
  flex: 0 0 auto;
}
.contact-icon svg{
  width: 20px;
  height: 20px;
}

.logo-marquee{
  background: var(--surface);
  border: 1px solid rgba(15, 23, 42, .08);
  border-radius: 18px;
  padding: 16px 0;
  overflow: hidden;
  box-shadow: 0 12px 32px rgba(2, 6, 23, .06);
}
.logo-track{
  display: flex;
  gap: 16px;
  width: max-content;
  animation: marquee 26s linear infinite;
}
.logo-marquee:hover .logo-track{
  animation-play-state: paused;
}
.logo-item{
  display: grid;
  place-items: center;
  padding: 0 6px;
}
.logo-item img{
  max-width: 100%;
  max-height: 200px;
 
  transition: opacity .18s ease, filter .18s ease, transform .18s ease;
}


@keyframes marquee{
  0%{ transform: translateX(0); }
  100%{ transform: translateX(-50%); }
}

.site-footer{
  background: #0b1220;
  color: rgba(255, 255, 255, .88);
  padding: 26px 0 11px;
}
.site-footer .text-muted{
  color: rgba(255, 255, 255, .62) !important;
}
.footer-title{
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  margin: 0 0 12px;
  color: rgba(255, 255, 255, .88);
}
.footer-links{
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 8px;
}
.footer-links a{
  color: rgba(255, 255, 255, .74);
  text-decoration: none;
}
.footer-links a:hover{
  color: #ffffff;
}
.footer-links--muted li,
.footer-links--muted a{
  color: rgba(255, 255, 255, .70);
}

.social{
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.social-btn{
  width: 42px;
  height: 42px;
  border-radius: 14px;
  background: rgba(255, 255, 255, .08);
  border: 1px solid rgba(255, 255, 255, .12);
  display: grid;
  place-items: center;
  color: rgba(255, 255, 255, .86);
  text-decoration: none;
  transition: transform .18s ease, background .18s ease, border-color .18s ease;
}
.social-btn:hover{
  transform: translateY(-2px);
  background: rgba(255, 255, 255, .12);
  border-color: rgba(255, 255, 255, .20);
  color: #ffffff;
}
.social-btn svg{
  width: 18px;
  height: 18px;
}

.footer-bottom{
  margin-top: 34px;
  padding-top: 16px;
  border-top: 1px solid rgba(255, 255, 255, .10);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}

@media (min-width: 576px){
  .project-card,
  .testimonial-card,
  .blog-card,
  .about-review{
    flex-basis: 62%;
  }
}
@media (min-width: 768px){
  .project-card,
  .testimonial-card,
  .blog-card,
  .about-review{
    flex-basis: 44%;
  }
}
@media (min-width: 992px){
  .project-card{
    flex-basis: 32%;
  }
  .testimonial-card{
    flex-basis: 40%;
  }
  .blog-card{
    flex-basis: 32%;
  }
  .about-review{
    flex-basis: 32%;
  }
  .project-img{ height: 200px; }
}
@media (min-width: 1200px){
  .project-card{ flex-basis: 24%; }
  .blog-card{ flex-basis: 24%; }
  .testimonial-card{ flex-basis: 32%; }
  .about-review{ flex-basis: 32%; }
}

@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior: auto; }
  .logo-track{ animation: none; }
  .reel{ scroll-behavior: auto; }
}
