﻿/* Premium Alozix case-study cards.
   Loaded after projects.css; scoped to Projects / Case Studies cards only. */

#all-projects {
  max-width: 1320px !important;
}

.proj-grid {
  gap: 34px !important;
  align-items: stretch;
}

.proj-card {
  --case-gold: #cda447;
  --case-gold-bright: #f0cf7a;
  --case-gold-deep: #8f6b22;
  --case-panel: #090b10;
  --case-panel-soft: #10131a;
  position: relative !important;
  display: flex !important;
  flex-direction: column !important;
  min-height: 100% !important;
  overflow: hidden !important;
  padding: 0 !important;
  border-radius: 28px !important;
  border: 1px solid rgba(205, 164, 71, 0.48) !important;
  background:
    radial-gradient(circle at 50% -6%, rgba(205,164,71,0.16), transparent 34%),
    linear-gradient(180deg, #11141b 0%, #08090d 100%) !important;
  box-shadow:
    0 30px 76px rgba(0,0,0,0.78),
    0 0 0 1px rgba(205,164,71,0.06),
    inset 0 1px 0 rgba(255,255,255,0.055) !important;
  transition: transform 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease !important;
}

.proj-card::before {
  content: '';
  position: absolute;
  inset: 1px;
  z-index: 7;
  border-radius: 27px;
  border: 1px solid rgba(255,230,170,0.07);
  pointer-events: none;
}

.proj-card:hover {
  transform: translateY(-6px) !important;
  border-color: rgba(240,207,122,0.72) !important;
  box-shadow:
    0 36px 88px rgba(0,0,0,0.84),
    0 0 38px rgba(205,164,71,0.10),
    inset 0 1px 0 rgba(255,255,255,0.07) !important;
}

.proj-card-hero,
.proj-img-wrap {
  position: relative !important;
  aspect-ratio: 16 / 10 !important;
  min-height: 220px !important;
  max-height: 270px !important;
  overflow: hidden !important;
  border-radius: 27px 27px 0 0 !important;
  background:
    radial-gradient(ellipse at 50% 42%, rgba(240,207,122,0.20) 0%, rgba(205,164,71,0.08) 34%, transparent 62%),
    linear-gradient(180deg, #151922 0%, #090b10 100%) !important;
  isolation: isolate;
}

.proj-img-wrap::before {
  content: '' !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: 1 !important;
  pointer-events: none !important;
  background:
    radial-gradient(circle at 50% 38%, rgba(240,207,122,0.22), transparent 34%),
    linear-gradient(rgba(205,164,71,0.026) 1px, transparent 1px),
    linear-gradient(90deg, rgba(205,164,71,0.026) 1px, transparent 1px) !important;
  background-size: 100% 100%, 42px 42px, 42px 42px !important;
}

.proj-img-wrap::after {
  content: '' !important;
  position: absolute !important;
  inset: auto 0 0 0 !important;
  z-index: 3 !important;
  height: 34% !important;
  pointer-events: none !important;
  background: linear-gradient(180deg, transparent 0%, rgba(9,11,16,0.28) 44%, rgba(9,11,16,0.82) 100%) !important;
  opacity: 1 !important;
  transform: none !important;
  border: 0 !important;
  color: transparent !important;
  font-size: 0 !important;
  padding: 0 !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

.proj-img-wrap picture {
  position: absolute !important;
  inset: 20px 22px 58px !important;
  z-index: 2 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.proj-img {
  position: relative !important;
  inset: auto !important;
  z-index: 2 !important;
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center center !important;
  opacity: 1 !important;
  filter: saturate(1.08) contrast(1.08) brightness(0.98) !important;
  mix-blend-mode: normal !important;
  transform: none !important;
  transition: transform 0.32s ease, filter 0.32s ease !important;
}

.proj-img.proj-img--loading,
.proj-img.proj-img--loaded {
  opacity: 1 !important;
  filter: saturate(1.08) contrast(1.08) brightness(0.98) !important;
}

.proj-card:hover .proj-img {
  transform: scale(1.025) !important;
  opacity: 1 !important;
  filter: saturate(1.12) contrast(1.1) brightness(1.03) !important;
}

.proj-thumb {
  display: none !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

.proj-img-overlay {
  position: absolute !important;
  left: 50% !important;
  right: auto !important;
  bottom: 18px !important;
  z-index: 5 !important;
  display: flex !important;
  justify-content: center !important;
  flex-wrap: wrap !important;
  gap: 9px !important;
  width: calc(100% - 42px) !important;
  transform: translateX(-50%) !important;
}

.proj-tag {
  display: inline-flex !important;
  align-items: center !important;
  min-height: 29px !important;
  padding: 6px 13px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(240,207,122,0.46) !important;
  background: rgba(8,9,13,0.76) !important;
  color: #efd28a !important;
  font-size: 0.71rem !important;
  font-weight: 800 !important;
  letter-spacing: 0.01em !important;
  line-height: 1 !important;
  box-shadow: 0 9px 22px rgba(0,0,0,0.34), inset 0 1px 0 rgba(255,255,255,0.07) !important;
  backdrop-filter: blur(6px) !important;
  -webkit-backdrop-filter: blur(6px) !important;
}

.proj-body {
  display: flex !important;
  flex: 1 !important;
  flex-direction: column !important;
  gap: 17px !important;
  padding: 30px 28px 26px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.026), rgba(255,255,255,0) 22%),
    var(--case-panel) !important;
}

.proj-card-eyebrow {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 10px !important;
}

.proj-category {
  display: inline-flex !important;
  align-items: center !important;
  width: fit-content !important;
  padding: 7px 14px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(205,164,71,0.42) !important;
  background: rgba(205,164,71,0.09) !important;
  color: #efd28a !important;
  font-size: 0.71rem !important;
  font-weight: 900 !important;
  letter-spacing: 0.09em !important;
  line-height: 1 !important;
  text-transform: uppercase !important;
}

.proj-package {
  margin: 0 !important;
  color: rgba(184,196,216,0.68) !important;
  font-size: 0.78rem !important;
  font-weight: 600 !important;
  letter-spacing: 0 !important;
}

.proj-title {
  margin: 0 !important;
  color: #fff4d3 !important;
  font-size: clamp(1.32rem, 1.55vw, 1.68rem) !important;
  font-weight: 900 !important;
  line-height: 1.18 !important;
  letter-spacing: 0 !important;
}

.proj-desc {
  margin: 0 !important;
  color: rgba(222,229,240,0.84) !important;
  font-size: 0.96rem !important;
  line-height: 1.8 !important;
  flex: 0 0 auto !important;
}

.proj-benefits,
.proj-stats {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(92px, 1fr)) !important;
  gap: 0 !important;
  margin: 3px 0 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
  border: 1px solid rgba(205,164,71,0.24) !important;
  border-radius: 16px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0)),
    rgba(255,255,255,0.035) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.055) !important;
}

.proj-stat {
  position: relative !important;
  display: flex !important;
  min-height: 82px !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 7px !important;
  padding: 14px 12px !important;
  text-align: center !important;
}

.proj-stat + .proj-stat::before {
  content: '' !important;
  position: absolute !important;
  top: 17px !important;
  bottom: 17px !important;
  left: 0 !important;
  width: 1px !important;
  background: rgba(205,164,71,0.24) !important;
}

.proj-stat-num {
  color: #f0cf7a !important;
  font-size: 1.18rem !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  text-shadow: 0 0 15px rgba(205,164,71,0.18) !important;
}

.proj-stat-label {
  color: rgba(222,228,239,0.78) !important;
  font-size: 0.72rem !important;
  font-weight: 700 !important;
  line-height: 1.28 !important;
}

.proj-tech {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
}

.proj-tech-tag {
  padding: 6px 11px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(255,255,255,0.11) !important;
  background: rgba(255,255,255,0.045) !important;
  color: rgba(178,190,211,0.78) !important;
  font-size: 0.72rem !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  white-space: nowrap !important;
}

.proj-cta-zone {
  display: flex !important;
  flex-direction: column !important;
  gap: 16px !important;
  margin-top: auto !important;
  padding-top: 4px !important;
}

.proj-actions {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 12px !important;
  margin: 0 !important;
  padding: 0 !important;
}

.proj-actions .proj-info-btn:only-child {
  grid-column: 1 / -1 !important;
}

.proj-link,
.proj-info-btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 52px !important;
  margin: 0 !important;
  padding: 14px 18px !important;
  border-radius: 13px !important;
  font-family: 'Assistant', sans-serif !important;
  font-size: 0.94rem !important;
  font-weight: 900 !important;
  line-height: 1.12 !important;
  text-align: center !important;
  text-decoration: none !important;
  white-space: normal !important;
  cursor: pointer !important;
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease, background 0.18s ease !important;
}

.proj-link {
  border: 1px solid rgba(240,207,122,0.68) !important;
  background: linear-gradient(135deg, #f4d785 0%, #d3aa43 48%, #9d741f 100%) !important;
  color: #120d05 !important;
  box-shadow: 0 12px 26px rgba(205,164,71,0.24), inset 0 1px 0 rgba(255,255,255,0.36) !important;
}

.proj-info-btn {
  border: 1px solid rgba(240,207,122,0.50) !important;
  background: linear-gradient(180deg, rgba(205,164,71,0.10), rgba(205,164,71,0.035)) !important;
  color: #efd28a !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.05) !important;
}

.proj-link:hover,
.proj-info-btn:hover {
  transform: translateY(-1px) !important;
}

.proj-link:hover {
  color: #120d05 !important;
  box-shadow: 0 14px 32px rgba(205,164,71,0.34), inset 0 1px 0 rgba(255,255,255,0.42) !important;
}

.proj-info-btn:hover {
  border-color: rgba(240,207,122,0.72) !important;
  background: rgba(205,164,71,0.13) !important;
  color: #fff0bd !important;
}

.proj-card-text-links {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 18px !important;
  padding: 0 2px !important;
}

.proj-want-this-link {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 9px !important;
  min-width: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
  background: transparent !important;
  color: rgba(240,207,122,0.9) !important;
  font-size: 0.92rem !important;
  font-weight: 800 !important;
  line-height: 1.35 !important;
  text-align: start !important;
  text-decoration: none !important;
  opacity: 1 !important;
}

.cs-card-link.proj-want-this-link {
  color: rgba(240,207,122,0.9) !important;
  font-size: 0.92rem !important;
  font-weight: 800 !important;
}

.proj-want-this-link::after {
  content: none !important;
}

.card-arrow {
  display: inline-block !important;
  flex: 0 0 auto !important;
  color: #efd28a !important;
  transition: transform 0.18s ease !important;
}

.proj-want-this-link:hover,
.cs-card-link.proj-want-this-link:hover {
  color: #fff0bd !important;
  text-decoration: none !important;
}

.proj-want-this-link:hover .card-arrow {
  transform: translateX(3px) !important;
}

[dir="rtl"] .proj-card-eyebrow,
[dir="rtl"] .proj-tech,
[dir="rtl"] .proj-card-text-links {
  direction: rtl !important;
}

[dir="rtl"] .proj-body,
[dir="rtl"] .proj-title,
[dir="rtl"] .proj-desc,
[dir="rtl"] .proj-package {
  text-align: right !important;
  direction: rtl !important;
}

[dir="rtl"] .proj-actions {
  direction: rtl !important;
}

[dir="rtl"] .proj-stat + .proj-stat::before {
  left: auto !important;
  right: 0 !important;
}

[dir="rtl"] .proj-card-text-links {
  flex-direction: row-reverse !important;
}

[dir="rtl"] .proj-want-this-link {
  flex-direction: row-reverse !important;
  text-align: right !important;
  direction: rtl !important;
}

[dir="rtl"] .card-arrow {
  transform: scaleX(-1) !important;
}

[dir="rtl"] .proj-want-this-link:hover .card-arrow {
  transform: scaleX(-1) translateX(3px) !important;
}

@media (max-width: 1100px) {
  .proj-grid {
    gap: 24px !important;
  }
  .proj-body {
    padding: 25px 22px 24px !important;
  }
  .proj-card-text-links {
    align-items: flex-start !important;
    flex-direction: column !important;
    gap: 10px !important;
  }
  [dir="rtl"] .proj-card-text-links {
    align-items: flex-end !important;
    flex-direction: column !important;
  }
}

@media (max-width: 760px) {
  .proj-card {
    border-radius: 24px !important;
  }
  .proj-card-hero,
  .proj-img-wrap {
    min-height: 210px !important;
    border-radius: 23px 23px 0 0 !important;
  }
  .proj-img-wrap picture {
    inset: 18px 18px 54px !important;
  }
  .proj-title {
    font-size: 1.27rem !important;
  }
  .proj-desc {
    font-size: 0.92rem !important;
  }
}

@media (max-width: 520px) {
  .proj-grid {
    gap: 20px !important;
  }
  .proj-body {
    padding: 22px 18px 22px !important;
    gap: 15px !important;
  }
  .proj-img-wrap {
    min-height: 198px !important;
  }
  .proj-actions {
    grid-template-columns: 1fr !important;
  }
  .proj-link,
  .proj-info-btn {
    width: 100% !important;
  }
  .proj-stat {
    min-height: 74px !important;
  }
}

@media (hover: none) and (pointer: coarse), (prefers-reduced-motion: reduce) {
  .proj-card,
  .proj-img,
  .proj-link,
  .proj-info-btn,
  .card-arrow {
    transition: none !important;
  }
  .proj-card:hover,
  .proj-link:hover,
  .proj-info-btn:hover {
    transform: none !important;
  }
  .proj-card:hover .proj-img {
    transform: none !important;
  }
}

/* Hero integration fix: full-width cover area attached to the card top. */
.proj-card-hero,
.proj-img-wrap {
  aspect-ratio: 16 / 9 !important;
  min-height: 238px !important;
  max-height: 282px !important;
  padding: 0 !important;
  margin: 0 !important;
  border-radius: 27px 27px 0 0 !important;
  overflow: hidden !important;
  background:
    radial-gradient(ellipse at 50% 38%, rgba(240,207,122,0.22), rgba(205,164,71,0.08) 34%, transparent 64%),
    linear-gradient(180deg, #151922 0%, #090b10 100%) !important;
}

.proj-img-wrap picture {
  position: absolute !important;
  inset: 0 !important;
  z-index: 2 !important;
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
}

.proj-img {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center center !important;
  border: 0 !important;
  border-radius: 0 !important;
}

.proj-img-wrap::before {
  z-index: 1 !important;
  background:
    radial-gradient(ellipse at 50% 38%, rgba(240,207,122,0.24), rgba(205,164,71,0.07) 38%, transparent 68%),
    linear-gradient(rgba(205,164,71,0.018) 1px, transparent 1px),
    linear-gradient(90deg, rgba(205,164,71,0.018) 1px, transparent 1px) !important;
  background-size: 100% 100%, 48px 48px, 48px 48px !important;
}

.proj-img-wrap::after {
  z-index: 4 !important;
  height: 42% !important;
  background: linear-gradient(180deg, transparent 0%, rgba(9,11,16,0.14) 35%, rgba(9,11,16,0.78) 100%) !important;
}

.proj-img-overlay {
  bottom: 17px !important;
  z-index: 6 !important;
  width: calc(100% - 36px) !important;
}

@media (max-width: 760px) {
  .proj-card-hero,
  .proj-img-wrap {
    min-height: 220px !important;
  }
}

@media (max-width: 520px) {
  .proj-card-hero,
  .proj-img-wrap {
    min-height: 204px !important;
  }
}

/* Final hero cover enforcement: no thumbnail frame, no inner media padding. */
.proj-card > .proj-img-wrap,
.proj-card > .proj-card-hero {
  position: relative !important;
  display: block !important;
  width: 100% !important;
  height: 248px !important;
  min-height: 248px !important;
  max-height: 248px !important;
  margin: 0 !important;
  padding: 0 !important;
  border-radius: 27px 27px 0 0 !important;
  overflow: hidden !important;
}

.proj-card > .proj-img-wrap picture,
.proj-card > .proj-card-hero picture {
  position: absolute !important;
  inset: 0 !important;
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  overflow: hidden !important;
}

.proj-card > .proj-img-wrap .proj-img,
.proj-card > .proj-card-hero .proj-img,
.proj-card > .proj-img-wrap .proj-img[src],
.proj-card > .proj-card-hero .proj-img[src] {
  position: absolute !important;
  inset: 0 !important;
  display: block !important;
  width: 100% !important;
  max-width: none !important;
  height: 100% !important;
  max-height: none !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  object-fit: cover !important;
  object-position: center center !important;
}

.proj-card > .proj-img-wrap .proj-img-overlay,
.proj-card > .proj-card-hero .proj-img-overlay {
  position: absolute !important;
  left: 50% !important;
  right: auto !important;
  bottom: 18px !important;
  transform: translateX(-50%) !important;
  width: calc(100% - 40px) !important;
  margin: 0 !important;
  z-index: 6 !important;
}

@media (max-width: 760px) {
  .proj-card > .proj-img-wrap,
  .proj-card > .proj-card-hero {
    height: 224px !important;
    min-height: 224px !important;
    max-height: 224px !important;
  }
}

@media (max-width: 520px) {
  .proj-card > .proj-img-wrap,
  .proj-card > .proj-card-hero {
    height: 208px !important;
    min-height: 208px !important;
    max-height: 208px !important;
  }
}

/* Internal alignment pass: keep the current design, align card sections. */
.proj-grid {
  align-items: stretch !important;
}

.proj-card {
  height: 100% !important;
}

.proj-body {
  display: grid !important;
  grid-template-rows:
    minmax(44px, auto)
    minmax(72px, auto)
    minmax(132px, auto)
    minmax(82px, auto)
    minmax(82px, auto)
    1fr
    auto !important;
  gap: 16px !important;
  height: 100% !important;
  align-content: start !important;
}

.proj-card-eyebrow {
  min-height: 44px !important;
  align-content: flex-start !important;
}

.proj-title {
  min-height: 72px !important;
  display: flex !important;
  align-items: flex-start !important;
}

.proj-desc {
  min-height: 132px !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 5;
  -webkit-box-orient: vertical;
  overflow: hidden !important;
}

.proj-stats,
.proj-benefits {
  min-height: 82px !important;
  align-self: stretch !important;
}

.proj-tech {
  min-height: 82px !important;
  align-content: flex-start !important;
}

.proj-cta-zone {
  align-self: end !important;
  margin-top: 0 !important;
  min-height: 124px !important;
}

.proj-actions {
  min-height: 52px !important;
}

.proj-card-text-links {
  min-height: 44px !important;
  align-items: flex-start !important;
}

@media (max-width: 1100px) {
  .proj-body {
    grid-template-rows:
      minmax(44px, auto)
      minmax(72px, auto)
      minmax(146px, auto)
      minmax(82px, auto)
      minmax(96px, auto)
      1fr
      auto !important;
  }

  .proj-desc {
    min-height: 146px !important;
    -webkit-line-clamp: 6;
  }

  .proj-tech {
    min-height: 96px !important;
  }

  .proj-cta-zone {
    min-height: 132px !important;
  }
}

@media (max-width: 760px) {
  .proj-body {
    display: flex !important;
    flex-direction: column !important;
    height: auto !important;
  }

  .proj-card-eyebrow,
  .proj-title,
  .proj-desc,
  .proj-stats,
  .proj-benefits,
  .proj-tech,
  .proj-cta-zone,
  .proj-actions,
  .proj-card-text-links {
    min-height: 0 !important;
  }

  .proj-desc {
    display: block !important;
    overflow: visible !important;
    -webkit-line-clamp: unset;
  }

  .proj-cta-zone {
    margin-top: auto !important;
  }
}

/* Professional section rhythm: named rows keep every card aligned. */
.proj-card {
  display: flex !important;
  flex-direction: column !important;
  height: 100% !important;
}

.proj-card > .proj-img-wrap,
.proj-card > .proj-card-hero {
  flex: 0 0 248px !important;
  height: 248px !important;
}

.proj-body {
  flex: 1 1 auto !important;
  display: grid !important;
  grid-template-areas:
    "eyebrow"
    "title"
    "desc"
    "stats"
    "tech"
    "cta" !important;
  grid-template-rows: 54px 86px 146px 88px 104px 126px !important;
  gap: 16px !important;
  height: auto !important;
  min-height: 700px !important;
  align-content: start !important;
}

.proj-card-eyebrow {
  grid-area: eyebrow !important;
  min-height: 0 !important;
  height: 54px !important;
  overflow: hidden !important;
  align-content: flex-start !important;
}

.proj-title {
  grid-area: title !important;
  min-height: 0 !important;
  height: 86px !important;
  display: flex !important;
  align-items: flex-start !important;
  overflow: hidden !important;
}

.proj-desc {
  grid-area: desc !important;
  min-height: 0 !important;
  height: 146px !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 5;
  -webkit-box-orient: vertical;
  overflow: hidden !important;
}

.proj-stats,
.proj-benefits {
  grid-area: stats !important;
  min-height: 0 !important;
  height: 88px !important;
  align-self: stretch !important;
}

.proj-tech {
  grid-area: tech !important;
  min-height: 0 !important;
  height: 104px !important;
  overflow: hidden !important;
  align-content: flex-start !important;
}

.proj-cta-zone {
  grid-area: cta !important;
  min-height: 0 !important;
  height: 126px !important;
  margin-top: 0 !important;
  align-self: stretch !important;
  display: grid !important;
  grid-template-rows: 54px 48px !important;
  gap: 16px !important;
}

.proj-actions {
  min-height: 0 !important;
  height: 54px !important;
  align-self: stretch !important;
}

.proj-card-text-links {
  min-height: 0 !important;
  height: 48px !important;
  align-self: stretch !important;
  align-items: flex-start !important;
}

@media (max-width: 1100px) and (min-width: 761px) {
  .proj-body {
    grid-template-rows: 56px 92px 166px 90px 118px 136px !important;
    min-height: 754px !important;
  }

  .proj-card-eyebrow { height: 56px !important; }
  .proj-title { height: 92px !important; }

  .proj-desc {
    height: 166px !important;
    -webkit-line-clamp: 6;
  }

  .proj-stats,
  .proj-benefits { height: 90px !important; }

  .proj-tech { height: 118px !important; }

  .proj-cta-zone {
    height: 136px !important;
    grid-template-rows: 54px 58px !important;
  }

  .proj-card-text-links {
    height: 58px !important;
  }
}

@media (max-width: 760px) {
  .proj-card > .proj-img-wrap,
  .proj-card > .proj-card-hero {
    flex-basis: 224px !important;
    height: 224px !important;
  }

  .proj-body {
    display: flex !important;
    flex-direction: column !important;
    min-height: 0 !important;
    height: auto !important;
  }

  .proj-card-eyebrow,
  .proj-title,
  .proj-desc,
  .proj-stats,
  .proj-benefits,
  .proj-tech,
  .proj-cta-zone,
  .proj-actions,
  .proj-card-text-links {
    height: auto !important;
    min-height: 0 !important;
    overflow: visible !important;
  }

  .proj-desc {
    display: block !important;
    -webkit-line-clamp: unset;
  }

  .proj-cta-zone {
    display: flex !important;
    flex-direction: column !important;
    margin-top: auto !important;
  }
}

@media (max-width: 520px) {
  .proj-card > .proj-img-wrap,
  .proj-card > .proj-card-hero {
    flex-basis: 208px !important;
    height: 208px !important;
  }
}

/* Compact rhythm pass: preserve alignment without tall blank CTA gaps. */
.proj-body {
  grid-template-rows: 46px 74px 120px 82px 74px 112px !important;
  gap: 13px !important;
  min-height: 586px !important;
}

.proj-card-eyebrow {
  height: 46px !important;
}

.proj-title {
  height: 74px !important;
}

.proj-desc {
  height: 120px !important;
  -webkit-line-clamp: 4;
}

.proj-stats,
.proj-benefits {
  height: 82px !important;
}

.proj-tech {
  height: 74px !important;
}

.proj-cta-zone {
  height: 112px !important;
  grid-template-rows: 52px 42px !important;
  gap: 12px !important;
  margin-top: 0 !important;
  padding-top: 0 !important;
}

.proj-actions {
  height: 52px !important;
  min-height: 52px !important;
}

.proj-card-text-links {
  height: 42px !important;
  min-height: 42px !important;
}

@media (max-width: 1100px) and (min-width: 761px) {
  .proj-body {
    grid-template-rows: 48px 82px 136px 84px 88px 124px !important;
    gap: 13px !important;
    min-height: 660px !important;
  }

  .proj-card-eyebrow { height: 48px !important; }
  .proj-title { height: 82px !important; }

  .proj-desc {
    height: 136px !important;
    -webkit-line-clamp: 5;
  }

  .proj-stats,
  .proj-benefits { height: 84px !important; }

  .proj-tech { height: 88px !important; }

  .proj-cta-zone {
    height: 124px !important;
    grid-template-rows: 52px 46px !important;
    gap: 12px !important;
  }

  .proj-card-text-links {
    height: 46px !important;
  }
}

@media (max-width: 760px) {
  .proj-body {
    gap: 14px !important;
  }

  .proj-cta-zone {
    padding-top: 0 !important;
  }
}

/* Body-only compacting pass: do not touch hero/image dimensions. */
.proj-body {
  padding: 22px 24px 20px !important;
  grid-template-rows: 42px 64px 104px 76px 58px 98px !important;
  gap: 10px !important;
  min-height: 0 !important;
  height: auto !important;
}

.proj-card-eyebrow {
  height: 42px !important;
}

.proj-title {
  height: 64px !important;
}

.proj-desc {
  height: 104px !important;
  -webkit-line-clamp: 4;
}

.proj-stats,
.proj-benefits {
  height: 76px !important;
}

.proj-stat {
  min-height: 0 !important;
  padding-top: 10px !important;
  padding-bottom: 10px !important;
}

.proj-tech {
  height: 58px !important;
  gap: 6px !important;
}

.proj-tech-tag {
  padding-top: 5px !important;
  padding-bottom: 5px !important;
}

.proj-cta-zone {
  height: 98px !important;
  grid-template-rows: 48px 38px !important;
  gap: 10px !important;
  padding-top: 0 !important;
  margin-top: 0 !important;
}

.proj-actions {
  height: 48px !important;
  min-height: 48px !important;
}

.proj-link,
.proj-info-btn {
  min-height: 48px !important;
  padding-top: 11px !important;
  padding-bottom: 11px !important;
}

.proj-card-text-links {
  height: 38px !important;
  min-height: 38px !important;
  padding-bottom: 0 !important;
}

@media (max-width: 1100px) and (min-width: 761px) {
  .proj-body {
    padding: 21px 20px 20px !important;
    grid-template-rows: 44px 72px 118px 78px 68px 106px !important;
    gap: 10px !important;
    min-height: 0 !important;
  }

  .proj-card-eyebrow { height: 44px !important; }
  .proj-title { height: 72px !important; }

  .proj-desc {
    height: 118px !important;
    -webkit-line-clamp: 5;
  }

  .proj-stats,
  .proj-benefits { height: 78px !important; }

  .proj-tech { height: 68px !important; }

  .proj-cta-zone {
    height: 106px !important;
    grid-template-rows: 48px 42px !important;
    gap: 10px !important;
  }

  .proj-card-text-links { height: 42px !important; }
}

@media (max-width: 760px) {
  .proj-body {
    padding: 20px 18px 19px !important;
    gap: 11px !important;
  }

  .proj-cta-zone {
    gap: 10px !important;
  }
}

/* Mobile-only project card CTA/layout repair: keep hero unchanged, prevent footer overlap. */
@media (max-width: 768px) {
  .proj-grid {
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: hidden !important;
  }

  .proj-card {
    width: 100% !important;
    max-width: min(100%, 370px) !important;
    margin-inline: auto !important;
    overflow: hidden !important;
  }

  .proj-body {
    display: flex !important;
    flex-direction: column !important;
    padding: 17px 15px 16px !important;
    gap: 9px !important;
    height: auto !important;
    min-height: 0 !important;
    grid-template-rows: none !important;
  }

  .proj-card-eyebrow,
  .proj-title,
  .proj-desc,
  .proj-stats,
  .proj-benefits,
  .proj-tech,
  .proj-cta-zone,
  .proj-actions,
  .proj-card-text-links {
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    overflow: visible !important;
  }

  .proj-card-eyebrow {
    gap: 5px !important;
    margin: 0 !important;
  }

  .proj-title {
    font-size: clamp(1.12rem, 5vw, 1.32rem) !important;
    line-height: 1.18 !important;
    margin: 0 !important;
  }

  .proj-desc {
    font-size: 0.84rem !important;
    line-height: 1.55 !important;
    margin: 0 !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 4;
    -webkit-box-orient: vertical;
    overflow: hidden !important;
  }

  .proj-stats,
  .proj-benefits {
    padding: 9px 8px !important;
    gap: 0 !important;
  }

  .proj-stat {
    min-height: 0 !important;
    padding: 4px 5px !important;
  }

  .proj-stat-num {
    font-size: 0.92rem !important;
    line-height: 1.15 !important;
  }

  .proj-stat-label {
    font-size: 0.62rem !important;
    line-height: 1.18 !important;
  }

  .proj-tech {
    gap: 5px !important;
    margin: 0 !important;
  }

  .proj-tech-tag {
    padding: 4px 8px !important;
    font-size: 0.62rem !important;
    line-height: 1.15 !important;
  }

  .proj-cta-zone {
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
    margin-top: 2px !important;
    padding-top: 0 !important;
  }

  .proj-actions {
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .proj-link,
  .proj-info-btn {
    width: 100% !important;
    min-height: 42px !important;
    padding: 10px 13px !important;
    font-size: 0.86rem !important;
    line-height: 1.15 !important;
    border-radius: 11px !important;
    flex: 0 0 auto !important;
  }

  .proj-card-text-links {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    justify-content: flex-start !important;
    gap: 7px !important;
    width: 100% !important;
    padding: 2px 1px 0 !important;
    margin: 0 !important;
  }

  .proj-want-this-link,
  .cs-card-link.proj-want-this-link {
    width: 100% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 10px !important;
    font-size: 0.8rem !important;
    line-height: 1.3 !important;
    padding: 0 !important;
    margin: 0 !important;
    white-space: normal !important;
  }

  [dir="rtl"] .proj-card-text-links {
    align-items: stretch !important;
    flex-direction: column !important;
  }

  [dir="rtl"] .proj-want-this-link,
  [dir="rtl"] .cs-card-link.proj-want-this-link {
    flex-direction: row-reverse !important;
    text-align: right !important;
  }
}

@media (max-width: 420px) {
  .proj-card {
    max-width: calc(100vw - 28px) !important;
  }

  .proj-body {
    padding: 16px 14px 15px !important;
    gap: 8px !important;
  }

  .proj-desc {
    -webkit-line-clamp: 3;
  }

  .proj-link,
  .proj-info-btn {
    min-height: 40px !important;
    padding-block: 9px !important;
  }
}

/* Mobile-only project tech tag grid. */
@media (max-width: 768px) {
  .proj-tech {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 6px !important;
    width: 100% !important;
    align-items: stretch !important;
  }

  .proj-tech-tag {
    width: 100% !important;
    max-width: 100% !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    box-sizing: border-box !important;
    text-align: center !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    min-height: 27px !important;
    padding: 5px 6px !important;
    font-size: 0.66rem !important;
    line-height: 1.15 !important;
  }
}

@media (max-width: 370px) {
  .proj-tech {
    gap: 5px !important;
  }

  .proj-tech-tag {
    font-size: 0.6rem !important;
    padding-inline: 4px !important;
  }
}
