.Portfolio {
  text-align: center;
  width: 100%;
  padding: clamp(14px, 2vw, 20px);
  background: linear-gradient(180deg, #f4fbfd 0%, #ffffff 100%);
}
.Portfolio .PortfolioHero {
  display: flex;
  flex-direction: column;
  gap: clamp(24px, 3vw, 40px);
  padding: clamp(24px, 4vw, 48px);
  justify-content: center;
  border-radius: 20px;
  background: radial-gradient(circle at top left, #e2fbff 0%, #ffffff 60%);
  box-shadow: 0 35px 80px rgba(0, 97, 116, 0.12);
}
.Portfolio .PortfolioEyebrow {
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-size: 0.75rem;
  color: #008e9b;
  font-weight: 600;
  margin: 0;
}
.Portfolio .PortfolioTitle {
  font-size: clamp(2rem, 3.5vw, 2.75rem);
  font-weight: 700;
  color: #062024;
  margin: 0;
}
.Portfolio .PortfolioLead {
  margin-top: 1rem;
  font-size: 1rem;
  line-height: 1.6;
  color: #4a5568;
}
.Portfolio .PortfolioStats {
  display: flex;
  flex-wrap: wrap;
  gap: 1.5rem;
  justify-content: center;
  list-style: none;
  padding: 0;
  margin: 2rem 0 0;
}
.Portfolio .PortfolioStatValue {
  display: block;
  font-size: 1.5rem;
  font-weight: 600;
  color: #062024;
}
.Portfolio .PortfolioStatLabel {
  display: block;
  font-size: 0.85rem;
  color: #5a6a72;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.Portfolio .PortfolioGallery {
  padding: 3rem 0;
}
.Portfolio .PortfolioGallery .PortfolioGalleryContainer {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 1.5rem;
}
@media (max-width: 450px) {
  .Portfolio .PortfolioGallery .PortfolioGalleryContainer {
    padding: 0;
  }
}
.Portfolio .PortfolioGallery .PortfolioGalleryList {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: flex-start;
  gap: 1.5rem;
  width: 100%;
}
.Portfolio .PortfolioGallery .PortfolioArrowLeft,
.Portfolio .PortfolioGallery .PortfolioArrowRight {
  border: none;
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: #0f1c24;
  color: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.35rem;
  cursor: pointer;
  transition: background 0.2s ease, transform 0.2s ease;
}
.Portfolio .PortfolioGallery .PortfolioArrowLeft:hover,
.Portfolio .PortfolioGallery .PortfolioArrowRight:hover {
  background: #163041;
  transform: translateY(-2px);
}
.Portfolio .PortfolioGallery .PortfolioArrowLeft:active,
.Portfolio .PortfolioGallery .PortfolioArrowRight:active {
  transform: translateY(0);
}
.Portfolio .PortfolioGallery .PortfolioCaseCardWrap {
  width: min(100%, 1120px);
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}
.Portfolio .PortfolioGallery .PortfolioCaseTitle {
  margin: 0;
  font-size: clamp(1.5rem, 2.5vw, 2rem);
  font-weight: 600;
  color: #062024;
  text-align: center;
}
.Portfolio .PortfolioGallery .PortfolioCaseCard {
  display: flex;
  flex-direction: column;
  gap: 1.75rem;
  padding: 2rem;
  background-color: #ffffff;
  border-radius: 1rem;
  box-shadow: 0 20px 50px rgba(6, 32, 36, 0.08);
  width: 100%;
  text-align: left;
  animation: fadeInSlide 0.4s ease;
}
.Portfolio .PortfolioGallery .PortfolioCaseContent {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.Portfolio .PortfolioGallery .PortfolioCaseProblemSolution {
  display: flex;
  gap: 1.25rem;
  flex-wrap: wrap;
}
.Portfolio .PortfolioGallery .PortfolioCaseProblem,
.Portfolio .PortfolioGallery .PortfolioCaseSolution,
.Portfolio .PortfolioGallery .PortfolioCaseDoctors,
.Portfolio .PortfolioGallery .PortfolioCaseDuration {
  font-size: 0.95rem;
  color: #4a5e65;
  margin: 0;
  line-height: 1.45;
}
.Portfolio .PortfolioGallery .PortfolioCaseDoctors {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}
.Portfolio .PortfolioGallery .PortfolioDoctorList {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}
.Portfolio .PortfolioGallery .PortfolioDoctorLink {
  display: inline-flex;
  align-items: center;
  padding: 0.35rem 0.85rem;
  border-radius: 999px;
  background: #eef4f7;
  color: #153954;
  font-weight: 500;
  font-size: 0.9rem;
  text-decoration: none;
  transition: background 0.2s ease;
}
.Portfolio .PortfolioGallery .PortfolioDoctorLink:hover {
  background: #dae6ef;
}
.Portfolio .PortfolioGallery .PortfolioComparison {
  width: 100%;
  background: #ffffff;
  border-radius: 1rem;
  box-shadow: inset 0 0 0 1px rgba(15, 28, 36, 0.05);
  text-align: left;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.Portfolio .PortfolioGallery .PortfolioComparisonHeader {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 1rem;
  margin-bottom: 1rem;
}
.Portfolio .PortfolioGallery .PortfolioComparisonMeta {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}
.Portfolio .PortfolioGallery .PortfolioComparisonCounter {
  font-size: 0.85rem;
  color: #4a5e65;
}
.Portfolio .PortfolioGallery .PortfolioComparisonControls {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
}
.Portfolio .PortfolioGallery .PortfolioComparisonControlButton {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 1px solid rgba(6, 32, 36, 0.15);
  background: #ffffff;
  color: #0f1c24;
  font-size: 1rem;
  cursor: pointer;
  transition: background 0.2s ease, color 0.2s ease;
}
.Portfolio .PortfolioGallery .PortfolioComparisonControlButton:hover {
  background: #0f1c24;
  color: #ffffff;
}
.Portfolio .PortfolioGallery .PortfolioComparisonBadge {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.75rem;
  font-weight: 600;
  color: #0e7257;
  background: #ecf7f0;
  border-radius: 999px;
  padding: 0.35rem 0.9rem;
}
.Portfolio .PortfolioGallery .PortfolioComparisonTitle {
  margin: 0;
  font-size: 1.25rem;
  font-weight: 600;
  color: #062024;
}
.Portfolio .PortfolioGallery .PortfolioComparisonSlider {
  width: 100%;
  height: clamp(220px, 42vw, 320px);
  border-radius: 1rem;
  overflow: hidden;
}
.Portfolio .PortfolioGallery .PortfolioAdditionalMedia {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.Portfolio .PortfolioGallery .PortfolioAdditionalMediaTitle {
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: #5a6570;
}
.Portfolio .PortfolioGallery .PortfolioAdditionalMediaGrid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 0.75rem;
}
.Portfolio .PortfolioGallery .PortfolioAdditionalMediaImage {
  width: 100%;
  height: 140px;
  object-fit: cover;
  border-radius: 0.65rem;
  box-shadow: 0 6px 18px rgba(6, 32, 36, 0.08);
}
@media (max-width: 960px) {
  .Portfolio .PortfolioArrowLeft,
  .Portfolio .PortfolioArrowRight {
    width: 44px;
    height: 44px;
    font-size: 1.1rem;
  }
}
@media (max-width: 960px) {
  .Portfolio .PortfolioCaseCard {
    padding: 1.5rem;
    gap: 1.25rem;
  }
}
@media (max-width: 600px) {
  .Portfolio .PortfolioComparison {
    max-width: 100%;
    min-width: unset;
    width: 100%;
    padding: 0;
  }
}
@media (max-width: 600px) {
  .Portfolio .PortfolioComparisonControls {
    width: 100%;
    justify-content: flex-end;
  }
}
@media (max-width: 600px) {
  .Portfolio .PortfolioComparisonSlider {
    border-radius: 0.75rem;
  }
}
@media (max-width: 600px) {
  .Portfolio .PortfolioAdditionalMediaImage {
    height: 120px;
  }
}
.Portfolio .PortfolioMetaLabel {
  display: block;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: #8a9aa5;
  margin-bottom: 0.35rem;
}
.Portfolio .PortfolioEmpty,
.Portfolio .PortfolioError {
  padding: 2rem;
  border-radius: 1rem;
  background-color: #f7fafc;
  color: #4a5568;
  font-size: 1rem;
}
.Portfolio .PortfolioError {
  background-color: #fff5f5;
  color: #c53030;
}
.Portfolio .PortfolioSkeleton {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding: 2rem;
}
.Portfolio .PortfolioSkeletonBanner,
.Portfolio .PortfolioSkeletonContent span {
  background: linear-gradient(90deg, #f3f6f9 0%, #e3edf7 50%, #f3f6f9 100%);
  background-size: 400% 400%;
  animation: shimmer 1.4s ease infinite;
  border-radius: 12px;
}
.Portfolio .PortfolioSkeletonBanner {
  height: 220px;
}
.Portfolio .PortfolioSkeletonContent {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.Portfolio .PortfolioSkeletonContent span {
  display: block;
  height: 16px;
}

.PortfolioCaseProblemSolution {
  display: flex;
  flex-direction: row;
  gap: 1rem;
}
@media (max-width: 768px) {
  .PortfolioCaseProblemSolution {
    flex-direction: column;
  }
}

@keyframes fadeInSlide {
  0% {
    opacity: 0;
    transform: translateY(24px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes shimmer {
  0% {
    background-position: 0% 50%;
  }
  100% {
    background-position: -135% 50%;
  }
}