/* =========================================================
   Modern Elegant Theme — Deed Palette (Dark-first)
   Shared variables, base, layout, components, utilities
   ========================================================= */

:root{
  /* === Brand Palette (from Deed logo) === */
  --brand-navy:#1A2C55;     /* main navy */
  --brand-teal:#0C7C90;     /* teal accent */
  --brand-red:#C62828;      /* red accent */

  /* Core (Dark) */
  --bg:#0b1220;             /* page background (deep navy) */
  --bg-soft:#0f1a2a;        /* muted sections */
  --surface:#122135;        /* cards/surfaces */
  --surface-2:#102033;      /* elevated surfaces */
  --text:#EAF0F7;           /* primary text */
  --muted:#A9B6C8;          /* secondary text */
  --accent:var(--brand-teal);
  --accent-ink:#ffffff;
  --indigo:#59BFCF;         /* link/hover tint (teal-ish) */
  --border:#223249;         /* soft border */
  --ring:#7FD3E2;           /* focus ring (light teal) */
  --shadow:0 12px 40px rgba(0,0,0,.35);

  /* Motion & Radius */
  --r-sm:10px; --r-md:14px; --r-lg:18px; --r-xl:22px;
  --trans-fast:140ms cubic-bezier(.2,.6,.2,1);
  --trans-slow:260ms cubic-bezier(.2,.6,.2,1);

  /* Typography */
  --font: Inter, system-ui, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  --leading: 1.55;

  /* Decorative */
  --glass: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  --danger: var(--brand-red);
}

@media (prefers-color-scheme: light){
  :root{
    --bg:#f5f8fb; --bg-soft:#eef3f8; --surface:#ffffff; --surface-2:#f7fbff;
    --text:#444b5be6; --muted:#5f6b7a; --accent:var(--brand-teal); --accent-ink:#ffffff;
    --indigo:#2f9fb1; --border:#dde5ef; --ring:#7FD3E2; --shadow:0 10px 30px rgba(16,22,33,.10);
  }
}

/* Base --------------------------------------------------- */
*{box-sizing:border-box}
html,body{
  margin:0; padding:0; background:var(--bg); color:var(--text);
  font-family:var(--font); line-height:var(--leading);
  -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  overflow-x: hidden;  /* Prevent horizontal scrolling */
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none;transition:color var(--trans-fast),opacity var(--trans-fast)}
a:hover{color:var(--indigo)}
::selection{background:rgba(12,124,144,.25)}

.container{width:min(1200px,93vw);margin-inline:auto}
.section{padding:10px 0}
.section-muted{background:var(--bg-soft)}
.section-accent{background:linear-gradient(180deg,var(--surface),var(--bg))}
.section-header{margin-bottom:24px}

.h1{font-size:clamp(28px,5vw,44px);margin:0 0 12px}
.h2{font-size:clamp(24px,4vw,34px);margin:0 0 8px}
.h3{font-size:clamp(20px,3vw,24px);margin:20px 0 8px}
.h4{font-size:clamp(18px,2.6vw,20px);margin:8px 0}
.h5{font-size:16px;margin:6px 0}
.lead{font-size:clamp(16px,2.6vw,20px);color:var(--muted)}
.muted{color:var(--muted)}

.list-plain{list-style:none;padding-left:0;margin:0}
.bullets{padding-left:1rem}

/* Buttons ------------------------------------------------ */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:10px 16px; border-radius:999px;
  background:var(--accent); color:var(--accent-ink); font-weight:700;
  border:1px solid transparent; box-shadow:var(--shadow);
  transition:filter var(--trans-fast), transform var(--trans-fast), box-shadow var(--trans-fast);
}
.btn:hover{filter:brightness(1.05); transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn:focus-visible{outline:3px solid var(--ring); outline-offset:2px}

.btn-outline{background:transparent;border:1px solid var(--border);color:var(--text);box-shadow:none}
.btn-outline:hover{background:rgba(255,255,255,.04)}

.btn-secondary{background:var(--surface-2);color:var(--text);border:1px solid var(--border)}
.btn-secondary:hover{filter:brightness(1.05)}

.btn-light{background:#fff;color:#111;border:1px solid rgba(0,0,0,.06);box-shadow:var(--shadow)}

.btn-icon{
  background:var(--surface-2); border:1px solid var(--border);
  border-radius:999px; padding:8px 12px;
  transition:transform var(--trans-fast), background var(--trans-fast)
}
.btn-icon:hover{transform:translateY(-1px)}

/* Layout grids ------------------------------------------ */
.grid-2{display:grid;gap:28px;grid-template-columns:1fr}
.grid-3{display:grid;gap:18px;grid-template-columns:1fr}
@media(min-width:900px){
  .grid-2{grid-template-columns:1.1fr .9fr}
  .grid-3{grid-template-columns:1fr 1fr 1fr}
}

/* Cards -------------------------------------------------- */
.cards{display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(270px,1fr))}
.card{
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow);
  transition:transform var(--trans-slow), box-shadow var(--trans-slow), border-color var(--trans-fast);
}
.card:hover{transform:translateY(-3px); box-shadow:0 16px 50px rgba(0,0,0,.45); border-color:rgba(12,124,144,.35)}
.card-media img{aspect-ratio:3/2;object-fit:cover}
.card-body{padding:16px}
.card-actions{display:flex;gap:10px;flex-wrap:wrap}

/* Progress ----------------------------------------------- */
.progress{
  position:relative; background:rgba(255,255,255,.08);
  border-radius:999px; height:10px; margin:8px 0; border:1px solid var(--border);
}
.progress .bar{height:100%; background:var(--accent); border-radius:999px; transition:width var(--trans-slow)}
.progress.lg{height:14px}
.progress .pct{position:absolute; right:8px; top:-22px; font-size:12px; color:var(--muted)}

/* Testimonials ------------------------------------------- */
.testimonials{
  display:grid; grid-auto-flow:column; grid-auto-columns:minmax(260px,1fr);
  gap:16px; overflow:auto; scroll-snap-type:x mandatory; padding-bottom:8px
}
.t-card{
  scroll-snap-align:start; background:var(--surface); border:1px solid var(--border);
  border-radius:var(--r-md); padding:16px; transition:transform var(--trans-slow), box-shadow var(--trans-slow)
}
.t-card:hover{transform:translateY(-2px); box-shadow:var(--shadow)}
.t-card blockquote{margin:0 0 8px}

/* Footer ------------------------------------------------- */
/* =========================================================
   GLOBAL FOOTER — Deed Professional Footer
   Used across all pages
   Fast, clean, responsive, no image dependency
   ========================================================= */

.site-footer.deed-footer {
  position: relative;
  overflow: hidden;
  margin-top: 0;
  padding: clamp(28px, 4vw, 46px) 0 18px;
  border-top: 1px solid var(--border);
  background:
    radial-gradient(circle at 8% 0%, rgba(12,124,144,.12), transparent 32%),
    radial-gradient(circle at 95% 20%, rgba(198,40,40,.07), transparent 30%),
    linear-gradient(180deg, var(--surface), var(--bg-soft));
  color: var(--text);
}

.site-footer.deed-footer::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(12,124,144,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(12,124,144,.035) 1px, transparent 1px);
  background-size: 46px 46px;
  opacity: .32;
}

.site-footer.deed-footer > .container {
  position: relative;
  z-index: 1;
}

/* Main footer grid */
.deed-footer .footer-main {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
  align-items: start;
}

@media (min-width: 760px) {
  .deed-footer .footer-main {
    grid-template-columns: 1.2fr 1fr 1fr;
  }
}

@media (min-width: 1080px) {
  .deed-footer .footer-main {
    grid-template-columns: 1.35fr .85fr 1fr .85fr;
    gap: 22px;
  }
}

/* Footer cards */
.deed-footer .footer-brand,
.deed-footer .footer-column {
  min-width: 0;
  padding: 18px;
  border: 1px solid var(--border);
  border-radius: 20px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.02)),
    rgba(255,255,255,.025);
  box-shadow: 0 12px 30px rgba(16,22,33,.08);
}

.deed-footer .footer-brand {
  background:
    linear-gradient(135deg, rgba(26,44,85,.92), rgba(12,124,144,.78));
}

/* Text */
.deed-footer .footer-title {
  margin: 0 0 10px;
  color: var(--text);
  font-size: 15px;
  line-height: 1.25;
  letter-spacing: -.007em;
  font-weight: 900;
}

.deed-footer .footer-brand .footer-title {
  color: #fff;
  font-size: 16px;
}

.deed-footer .footer-text {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.65;
}

.deed-footer .footer-brand .footer-text {
  color: rgba(255,255,255,.84);
}

/* Lists */
.deed-footer .footer-list,
.deed-footer .footer-links {
  display: grid;
  gap: 9px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.deed-footer .footer-list li {
  display: grid;
  gap: 3px;
}

.deed-footer .footer-list span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 850;
  text-transform: uppercase;
  letter-spacing: .06em;
}

.deed-footer .footer-list a,
.deed-footer .footer-links a {
  color: var(--text);
  font-size: 14px;
  line-height: 1.5;
  overflow-wrap: anywhere;
  transition:
    color var(--trans-fast),
    transform var(--trans-fast);
}

.deed-footer .footer-list a:hover,
.deed-footer .footer-links a:hover {
  color: var(--accent);
}

.deed-footer .footer-links a {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.deed-footer .footer-links a::before {
  content: "";
  width: 7px;
  height: 7px;
  flex: 0 0 7px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 0 4px rgba(12,124,144,.12);
}

/* CTA */
.deed-footer .footer-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  margin-top: 16px;
  padding: 9px 15px;
  border: 1px solid rgba(255,255,255,.24);
  border-radius: 999px;
  background: rgba(255,255,255,.12);
  color: #fff;
  font-size: 13.5px;
  font-weight: 900;
  line-height: 1;
  transition:
    transform var(--trans-fast),
    background var(--trans-fast),
    border-color var(--trans-fast);
}

.deed-footer .footer-cta:hover {
  transform: translateY(-1px);
  color: #fff;
  background: rgba(255,255,255,.18);
  border-color: rgba(255,255,255,.34);
}

/* Bottom */
.deed-footer .footer-bottom {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 18px;
  padding-top: 16px;
  border-top: 1px solid var(--border);
  color: var(--muted);
}

.deed-footer .footer-bottom small {
  font-size: 12.5px;
  line-height: 1.5;
}

@media (min-width: 760px) {
  .deed-footer .footer-bottom {
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
  }
}

/* Mobile */
@media (max-width: 640px) {
  .site-footer.deed-footer {
    padding: 26px 0 16px;
  }

  .deed-footer .footer-main {
    gap: 14px;
  }

  .deed-footer .footer-brand,
  .deed-footer .footer-column {
    padding: 16px;
    border-radius: 18px;
  }

  .deed-footer .footer-cta {
    width: 100%;
  }

  .deed-footer .footer-bottom {
    text-align: center;
  }
}

/* Light mode */
@media (prefers-color-scheme: light) {
  .site-footer.deed-footer {
    background:
      radial-gradient(circle at 8% 0%, rgba(12,124,144,.10), transparent 32%),
      radial-gradient(circle at 95% 20%, rgba(198,40,40,.05), transparent 30%),
      linear-gradient(180deg, #ffffff, #eef3f8);
  }

  .deed-footer .footer-brand,
  .deed-footer .footer-column {
    box-shadow: 0 12px 28px rgba(16,22,33,.075);
  }

  .deed-footer .footer-column {
    background: rgba(255,255,255,.72);
  }
}
/* Forms -------------------------------------------------- */
.form{display:flex;flex-direction:column;gap:16px}
.form input,.form select,.form textarea{
  width:100%; padding:12px 14px; border-radius:var(--r-md);
  border:1px solid var(--border); background:var(--surface-2); color:var(--text);
  transition:border-color var(--trans-fast), box-shadow var(--trans-fast), background var(--trans-fast)
}
.form input::placeholder,.form textarea::placeholder{color:color-mix(in oklab, var(--muted) 85%, #fff 15%)}
.form input:focus,.form select:focus,.form textarea:focus{
  outline:none; border-color: rgba(12,124,144,.55); box-shadow:0 0 0 4px rgba(12,124,144,.20)
}
.form .grid-3{display:grid;gap:12px;grid-template-columns:1fr}
@media(min-width:900px){.form .grid-3{grid-template-columns:1fr 1fr 1fr}}

/* Tabs --------------------------------------------------- */
.tabs{display:flex;gap:8px;margin:8px 0 16px}
.tab{
  background:transparent; border:1px solid var(--border);
  padding:8px 12px; border-radius:var(--r-md);
  transition:background var(--trans-fast), border-color var(--trans-fast)
}
.tab:hover{border-color:rgba(12,124,144,.35)}
.tab.active{background:var(--surface-2); border-color:rgba(12,124,144,.45)}
.panel{display:none}
.panel.active{display:block}

/* Utilities ---------------------------------------------- */
.sr-only{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0
}
.filters-form{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:14px}
.map-placeholder{
  background:var(--surface-2); border:1px dashed var(--border);
  height:240px; border-radius:var(--r-md); display:flex; align-items:center; justify-content:center; color:var(--muted)
}
.hero-subpage{padding:3px 0}
.hero-project{position:relative}
.hero-project img{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:var(--r-lg)}
.hero-overlay{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;gap:12px;padding-bottom:6vh}
.timeline{list-style:none;padding:0}
.timeline li{
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--r-md); padding:12px; margin:10px 0;
  transition:transform var(--trans-fast), border-color var(--trans-fast)
}
.timeline li:hover{transform:translateY(-1px); border-color:rgba(12,124,144,.35)}

a:focus-visible,button:focus-visible,[role="button"]:focus-visible,
input:focus-visible,select:focus-visible,textarea:focus-visible{
  outline:3px solid var(--ring); outline-offset:2px; border-radius:calc(var(--r-sm) + 2px);
}

/* ===== Awards (vertical auto-scroller, Deed theme) ===== */
/* =========================================================
   AWARDS & RECOGNITION — Premium Vertical Auto Scroller
   Used globally through _awards.html
   Fast, responsive, smooth scrolling, no JS dependency
   ========================================================= */

.awards-section {
  position: relative;
  overflow: hidden;
  padding: clamp(30px, 4vw, 54px) 0;
  border-block: 1px solid var(--border);
  background:
    radial-gradient(circle at 8% 10%, rgba(12,124,144,.18), transparent 32%),
    radial-gradient(circle at 92% 20%, rgba(198,40,40,.10), transparent 30%),
    linear-gradient(180deg, #1A2C55, #0f1a2a);
  color: #EAF0F7;
}

.awards-section::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(127,211,226,.055) 1px, transparent 1px),
    linear-gradient(90deg, rgba(127,211,226,.055) 1px, transparent 1px);
  background-size: 46px 46px;
  opacity: .38;
}

.awards-section > .container {
  position: relative;
  z-index: 1;
}

/* Header */
.awards-header {
  max-width: 820px;
  margin: 0 auto 24px;
  text-align: center;
}

.awards-kicker {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  padding: 7px 13px;
  margin-bottom: 12px;
  border: 1px solid rgba(255,255,255,.25);
  border-radius: 999px;
  background: rgba(255,255,255,.11);
  color: #fff;
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
  letter-spacing: .10em;
  text-transform: uppercase;
}

.awards-header h2 {
  margin: 0;
  color: #fff;
  font-size: clamp(16px, 2vw, 26px);
  line-height: 1.18;
  letter-spacing: -.007em;
  font-weight: 900;
}

.awards-header p {
  max-width: 700px;
  margin: 12px auto 0;
  color: rgba(234,240,247,.82);
  font-size: clamp(15px, 1.35vw, 17px);
  line-height: 1.65;
}

/* Scroller shell */
.awards-shell {
  position: relative;
  max-width: 940px;
  margin: 0 auto;
  padding: 12px;
  border: 1px solid rgba(127,211,226,.22);
  border-radius: 26px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.075), rgba(255,255,255,.025)),
    rgba(10,25,50,.55);
  box-shadow: 0 18px 48px rgba(0,0,0,.26);
}

.awards-shell::before,
.awards-shell::after {
  content: "";
  position: absolute;
  left: 12px;
  right: 12px;
  z-index: 2;
  height: 56px;
  pointer-events: none;
}

.awards-shell::before {
  top: 12px;
  border-radius: 22px 22px 0 0;
  background: linear-gradient(180deg, rgba(15,26,42,.98), rgba(15,26,42,0));
}

.awards-shell::after {
  bottom: 12px;
  border-radius: 0 0 22px 22px;
  background: linear-gradient(0deg, rgba(15,26,42,.98), rgba(15,26,42,0));
}

/* Scroller */
.awards-scroller {
  --awards-height: 430px;
  --awards-gap: 14px;
  --awards-duration: 38s;

  position: relative;
  height: var(--awards-height);
  overflow: hidden;
  border-radius: 22px;
}

.awards-track {
  display: flex;
  flex-direction: column;
  gap: var(--awards-gap);
  margin: 0;
  padding: 0;
  list-style: none;
  animation: awards-scroll-up var(--awards-duration) linear infinite;
  will-change: transform;
}

.awards-scroller:hover .awards-track {
  animation-play-state: paused;
}

@keyframes awards-scroll-up {
  from {
    transform: translateY(0);
  }

  to {
    transform: translateY(-50%);
  }
}

/* Award item */
.award-card {
  display: grid;
  grid-template-columns: 82px 1fr;
  gap: 14px;
  align-items: center;
  min-height: 112px;
  padding: 14px;
  border: 1px solid rgba(127,211,226,.20);
  border-radius: 20px;
  background:
    linear-gradient(135deg, rgba(12,124,144,.13), rgba(198,40,40,.055)),
    rgba(255,255,255,.055);
  box-shadow: 0 10px 28px rgba(0,0,0,.16);
  transition:
    transform var(--trans-fast),
    border-color var(--trans-fast),
    background var(--trans-fast);
}

.award-card:hover {
  transform: translateY(-2px);
  border-color: rgba(127,211,226,.42);
  background:
    linear-gradient(135deg, rgba(12,124,144,.22), rgba(198,40,40,.10)),
    rgba(255,255,255,.075);
}

.award-logo {
  display: grid;
  place-items: center;
  width: 82px;
  height: 82px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.22);
  border-radius: 18px;
  background: rgba(255,255,255,.92);
  box-shadow: 0 12px 24px rgba(0,0,0,.16);
}

.award-logo img {
  width: 100%;
  height: 100%;
  padding: 9px;
  object-fit: contain;
}

.award-body {
  min-width: 0;
}

.award-body strong {
  display: block;
  color: #fff;
  font-size: 15.5px;
  line-height: 1.3;
  font-weight: 900;
  letter-spacing: -.007em;
}

.award-body span {
  display: block;
  margin-top: 4px;
  color: rgba(234,240,247,.72);
  font-size: 13px;
  line-height: 1.4;
}

.award-body p {
  margin: 7px 0 0;
  color: rgba(234,240,247,.86);
  font-size: 14px;
  line-height: 1.55;
}

/* Empty state */
.awards-empty {
  max-width: 720px;
  margin: 0 auto;
  padding: 24px;
  text-align: center;
  border: 1px solid rgba(127,211,226,.22);
  border-radius: 24px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.075), rgba(255,255,255,.025)),
    rgba(10,25,50,.55);
  box-shadow: 0 14px 38px rgba(0,0,0,.20);
}

.awards-empty strong {
  display: block;
  color: #fff;
  font-size: 16px;
  font-weight: 900;
}

.awards-empty p {
  margin: 8px 0 0;
  color: rgba(234,240,247,.78);
  font-size: 14.5px;
  line-height: 1.6;
}

/* Mobile */
@media (max-width: 640px) {
  .awards-section {
    padding: 28px 0 38px;
  }

  .awards-header {
    margin-bottom: 20px;
  }

  .awards-header h2 {
    font-size: clamp(16px, 2vw, 26px);
    letter-spacing: -.007em;
  }

  .awards-header p {
    font-size: 15px;
    line-height: 1.62;
  }

  .awards-shell {
    padding: 10px;
    border-radius: 22px;
  }

  .awards-shell::before,
  .awards-shell::after {
    left: 10px;
    right: 10px;
    height: 44px;
  }

  .awards-scroller {
    --awards-height: 360px;
    --awards-gap: 12px;
    border-radius: 18px;
  }

  .award-card {
    grid-template-columns: 68px 1fr;
    gap: 12px;
    min-height: 98px;
    padding: 12px;
    border-radius: 18px;
  }

  .award-logo {
    width: 68px;
    height: 68px;
    border-radius: 16px;
  }

  .award-logo img {
    padding: 7px;
  }

  .award-body strong {
    font-size: 14.5px;
  }

  .award-body span {
    font-size: 12.5px;
  }

  .award-body p {
    font-size: 13.5px;
    line-height: 1.5;
  }
}

/* Very small mobile */
@media (max-width: 420px) {
  .award-card {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .award-logo {
    margin: 0 auto;
  }
}

/* Accessibility */
@media (prefers-reduced-motion: reduce) {
  .awards-track {
    animation: none;
  }

  .awards-scroller {
    overflow-y: auto;
  }
}

/* Light mode */
@media (prefers-color-scheme: light) {
  .awards-section {
    background:
      radial-gradient(circle at 8% 10%, rgba(12,124,144,.12), transparent 32%),
      radial-gradient(circle at 92% 20%, rgba(198,40,40,.06), transparent 30%),
      linear-gradient(180deg, #1A2C55, #0f1a2a);
  }
}

/* =========================================================
   Form Feedback Enhancements — unified with Deed palette
   ========================================================= */

.form-group {
  display: flex;
  flex-direction: column;
  /*margin-bottom: 1.2rem;*/
}

.form-group label {
  font-weight: 600;
  margin-bottom: 6px;
  color: var(--text);
}

.form-group small.muted {
  margin-top: 4px;
  font-size: 0.85rem;
  color: var(--muted);
}

.field-error {
  margin-top: 4px;
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--danger);
  min-height: 1rem;
}

.form input:invalid,
.form textarea:invalid {
  border-color: color-mix(in srgb, var(--danger) 55%, var(--border));
}

.form input:valid,
.form textarea:valid {
  border-color: color-mix(in srgb, var(--accent) 50%, var(--border));
}

/* subtle animation for appearing error text */
.field-error {
  opacity: 0;
  transition: opacity var(--trans-fast) ease;
}
.field-error.active {
  opacity: 1;
}

/* grid adjustment for responsive layout */
.grid-3 .form-group {
  display: flex;
  flex-direction: column;
}

/* =========================================================
   ABOUT PAGE — Compact Elegant Professional Design
   Same Heading Size Across Full Page
   ========================================================= */

.about-page {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 8% 8%, rgba(12,124,144,.10), transparent 30%),
    radial-gradient(circle at 92% 10%, rgba(198,40,40,.055), transparent 28%),
    linear-gradient(180deg, var(--bg), var(--bg-soft));
}

.about-page::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(12,124,144,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(12,124,144,.035) 1px, transparent 1px);
  background-size: 46px 46px;
  opacity: .38;
}

/* Hero */
.about-hero-pro {
  position: relative;
  z-index: 1;
  padding: clamp(28px, 4vw, 48px) 0 clamp(28px, 4vw, 46px);
  border-bottom: 1px solid var(--border);
}

.about-hero-wrap {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(22px, 3.5vw, 42px);
  align-items: center;
}

@media (min-width: 960px) {
  .about-hero-wrap {
    grid-template-columns: 1.02fr .98fr;
  }
}

.about-hero-copy {
  max-width: 670px;
}

/* Small Label */
.about-kicker {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  padding: 7px 13px;
  margin-bottom: 12px;
  border: 1px solid rgba(12,124,144,.30);
  border-radius: 999px;
  background: rgba(12,124,144,.10);
  color: var(--accent);
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
  letter-spacing: .10em;
  text-transform: uppercase;
}

/* Same main heading size everywhere */
.about-heading,
.about-hero-copy .about-heading,
.about-section-head .about-heading,
.about-page h1.about-heading,
.about-page h2.about-heading {
  margin: 0;
  color: var(--text);
  font-size: clamp(16px, 2vw, 24px);
  line-height: 1.12;
  letter-spacing: -.007em;
  font-weight: 900;
}

/* Paragraph */
.about-lead {
  margin: 12px 0 0;
  max-width: 660px;
  color: var(--muted);
  font-size: clamp(15px, 1.35vw, 17px);
  line-height: 1.65;
}

.about-section-head .about-lead {
  margin-left: auto;
  margin-right: auto;
}

/* Buttons */
.about-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}

.about-hero-actions .btn {
  min-height: 42px;
  padding: 9px 17px;
}

/* Hero Points */
.about-hero-points {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  margin-top: 18px;
}

@media (min-width: 620px) {
  .about-hero-points {
    grid-template-columns: repeat(3, 1fr);
  }
}

.about-hero-points div {
  padding: 13px 14px;
  border: 1px solid var(--border);
  border-radius: 16px;
  background: rgba(255,255,255,.04);
  backdrop-filter: blur(8px);
}

.about-hero-points strong {
  display: block;
  color: var(--text);
  font-size: 16px;
  font-weight: 900;
  line-height: 1.2;
}

.about-hero-points span {
  display: block;
  margin-top: 3px;
  color: var(--muted);
  font-size: 12.5px;
  line-height: 1.35;
}

/* Hero Image */
.about-hero-visual {
  position: relative;
  isolation: isolate;
}

.about-hero-visual::before {
  content: "";
  position: absolute;
  inset: -12px;
  z-index: -1;
  border-radius: 28px;
  background:
    linear-gradient(135deg, rgba(12,124,144,.24), rgba(198,40,40,.12)),
    radial-gradient(circle at 70% 20%, rgba(255,255,255,.14), transparent 32%);
}

.about-image-card {
  padding: 10px;
  border: 1px solid rgba(12,124,144,.22);
  border-radius: 26px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.035)),
    var(--surface);
  box-shadow: 0 18px 52px rgba(0,0,0,.16);
}

.about-image-card img {
  width: 100%;
  aspect-ratio: 16 / 10.2;
  object-fit: cover;
  border-radius: 18px;
}

.about-floating-card {
  position: absolute;
  left: 18px;
  right: 18px;
  bottom: -18px;
  padding: 14px 16px;
  border: 1px solid rgba(12,124,144,.26);
  border-radius: 18px;
  background: color-mix(in srgb, var(--surface) 90%, transparent);
  backdrop-filter: blur(12px);
  box-shadow: 0 14px 38px rgba(0,0,0,.15);
}

.about-floating-card strong {
  display: block;
  color: var(--text);
  font-size: 15.5px;
  font-weight: 900;
}

.about-floating-card span {
  display: block;
  margin-top: 3px;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.4;
}

/* General Sections */
.about-section {
  position: relative;
  z-index: 1;
  padding: clamp(34px, 5vw, 54px) 0;
}

.about-section + .about-section {
  padding-top: clamp(30px, 4vw, 46px);
}

.about-section-head {
  max-width: 800px;
  margin: 0 auto 22px;
  text-align: center;
}

/* Story Box */
.about-story-box {
  max-width: 980px;
  margin: 0 auto;
  padding: clamp(20px, 3vw, 30px);
  border: 1px solid var(--border);
  border-radius: 24px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.065), rgba(255,255,255,.022)),
    var(--surface);
  box-shadow: 0 14px 40px rgba(16,22,33,.10);
  columns: 1;
  column-gap: 30px;
}

@media (min-width: 900px) {
  .about-story-box {
    columns: 2;
  }
}

.about-story-box p {
  break-inside: avoid;
  margin: 0 0 12px;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.65;
}

.about-story-box p:last-child {
  margin-bottom: 0;
}

/* Soft Section */
.about-soft {
  background:
    linear-gradient(135deg, rgba(12,124,144,.065), rgba(198,40,40,.028)),
    var(--bg-soft);
  border-block: 1px solid var(--border);
}

/* Highlight Grid */
.about-highlight-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}

@media (min-width: 700px) {
  .about-highlight-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1060px) {
  .about-highlight-grid {
    grid-template-columns: repeat(4, 1fr);
  }
}

/* Shared Cards */
.about-stat-card,
.about-feature-card,
.about-card-pro {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--border);
  border-radius: 22px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.065), rgba(255,255,255,.022)),
    var(--surface);
  box-shadow: 0 14px 38px rgba(16,22,33,.10);
  transition: transform var(--trans-slow), border-color var(--trans-fast), box-shadow var(--trans-slow);
}

.about-stat-card::after,
.about-feature-card::after,
.about-card-pro::after {
  content: "";
  position: absolute;
  width: 100px;
  height: 100px;
  right: -50px;
  top: -50px;
  border-radius: 50%;
  background: rgba(12,124,144,.09);
}

.about-stat-card:hover,
.about-feature-card:hover,
.about-card-pro:hover {
  transform: translateY(-3px);
  border-color: rgba(12,124,144,.40);
  box-shadow: 0 18px 48px rgba(0,0,0,.14);
}

/* Stat Cards */
.about-stat-card {
  padding: 18px;
}

.about-stat-card strong {
  display: block;
  margin: 10px 0 6px;
  color: var(--text);
  font-size: 19px;
  line-height: 1.2;
  font-weight: 900;
  letter-spacing: -.02em;
}

.about-stat-card p {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.58;
}

/* Feature Cards */
.about-feature-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}

@media (min-width: 900px) {
  .about-feature-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.about-feature-card {
  min-height: 205px;
  padding: 20px;
}

.about-icon {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 14px;
  background: linear-gradient(135deg, var(--brand-navy), var(--brand-teal));
  color: #fff;
  font-size: 12.5px;
  font-weight: 900;
  box-shadow: 0 10px 22px rgba(12,124,144,.24);
}

/* Card headings are also consistent */
.about-card-title,
.about-feature-card h3,
.about-card-pro h3 {
  margin: 12px 0 7px;
  color: var(--text);
  font-size: 20px;
  line-height: 1.22;
  letter-spacing: -.02em;
  font-weight: 900;
}

.about-feature-card p,
.about-card-pro p {
  margin: 0;
  color: var(--muted);
  font-size: 14.5px;
  line-height: 1.62;
}

/* Purpose / Mission / Vision / Values */
.about-card-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}

@media (min-width: 900px) {
  .about-card-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

.about-card-pro {
  padding: 20px;
}

.about-card-pro ul {
  display: grid;
  gap: 8px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.about-card-pro li {
  position: relative;
  padding-left: 22px;
  color: var(--muted);
  font-size: 14.5px;
  line-height: 1.52;
}

.about-card-pro li::before {
  content: "";
  position: absolute;
  left: 0;
  top: .62em;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 0 4px rgba(12,124,144,.12);
}

.about-card-pro li strong {
  display: block;
  color: var(--text);
  font-weight: 850;
  margin-bottom: 1px;
}

.about-card-pro li span {
  display: block;
}

/* Mobile */
@media (max-width: 640px) {
  .about-hero-pro {
    padding: 26px 0 38px;
  }

  .about-heading,
  .about-hero-copy .about-heading,
  .about-section-head .about-heading,
  .about-page h1.about-heading,
  .about-page h2.about-heading {
    font-size: clamp(28px, 7vw, 34px);
    line-height: 1.12;
  }

  .about-lead {
    font-size: 15px;
    line-height: 1.62;
  }

  .about-hero-actions {
    flex-direction: column;
    margin-top: 16px;
  }

  .about-hero-actions .btn {
    width: 100%;
  }

  .about-hero-points {
    margin-top: 16px;
  }

  .about-floating-card {
    position: relative;
    left: auto;
    right: auto;
    bottom: auto;
    margin: -14px 14px 0;
  }

  .about-section {
    padding: 32px 0;
  }

  .about-section + .about-section {
    padding-top: 30px;
  }

  .about-section-head {
    margin-bottom: 20px;
  }

  .about-story-box,
  .about-stat-card,
  .about-feature-card,
  .about-card-pro {
    border-radius: 20px;
  }

  .about-story-box {
    padding: 18px;
  }

  .about-stat-card,
  .about-feature-card,
  .about-card-pro {
    padding: 18px;
  }

  .about-card-title,
  .about-feature-card h3,
  .about-card-pro h3 {
    font-size: 20px;
  }
}

/* Light Mode */
@media (prefers-color-scheme: light) {
  .about-page {
    background:
      radial-gradient(circle at 8% 8%, rgba(12,124,144,.10), transparent 30%),
      radial-gradient(circle at 92% 10%, rgba(198,40,40,.045), transparent 28%),
      linear-gradient(180deg, #ffffff, #f5f8fb);
  }

  .about-hero-points div,
  .about-story-box,
  .about-stat-card,
  .about-feature-card,
  .about-card-pro,
  .about-image-card {
    box-shadow: 0 12px 34px rgba(16,22,33,.085);
  }
}
/* =========================================================
   PROJECTS PARTIAL — Premium Deed Project Listing
   Used by templates/partials/_projects.html
   Fast, scoped, responsive, no extra CSS file needed
   ========================================================= */

.projects-section {
  position: relative;
  overflow: hidden;
  padding: clamp(30px, 4vw, 54px) 0;
  background:
    radial-gradient(circle at 8% 5%, rgba(12,124,144,.11), transparent 30%),
    radial-gradient(circle at 92% 10%, rgba(198,40,40,.055), transparent 28%),
    linear-gradient(180deg, var(--bg), var(--bg-soft));
  color: var(--text);
}

.projects-section::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(12,124,144,.032) 1px, transparent 1px),
    linear-gradient(90deg, rgba(12,124,144,.032) 1px, transparent 1px);
  background-size: 46px 46px;
  opacity: .34;
}

.projects-container {
  position: relative;
  z-index: 1;
}

/* Header */
.projects-header {
  max-width: 820px;
  margin: 0 auto 22px;
  text-align: center;
}

.projects-kicker {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  margin-bottom: 12px;
  padding: 7px 13px;
  border: 1px solid rgba(12,124,144,.30);
  border-radius: 999px;
  background: rgba(12,124,144,.10);
  color: var(--accent);
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
  letter-spacing: .10em;
  text-transform: uppercase;
}

.projects-heading {
  margin: 0;
  color: var(--text);
  font-size: clamp(16px, 2vw, 26px);
  line-height: 1.18;
  letter-spacing: -.007em;
  font-weight: 900;
}

.projects-subheading {
  max-width: 690px;
  margin: 10px auto 0;
  color: var(--muted);
  font-size: clamp(15px, 1.35vw, 17px);
  line-height: 1.65;
}

/* Filter panel */
.projects-filter-panel {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  margin: 0 0 22px;
  padding: 14px;
  border: 1px solid var(--border);
  border-radius: 24px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.065), rgba(255,255,255,.022)),
    var(--surface);
  box-shadow: 0 14px 38px rgba(16,22,33,.10);
}

@media (min-width: 760px) {
  .projects-filter-panel {
    grid-template-columns: 1fr 1fr 1.3fr auto;
    align-items: end;
  }
}

.project-filter-field {
  display: grid;
  gap: 7px;
  min-width: 0;
}

.project-filter-field label {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
  letter-spacing: .07em;
  text-transform: uppercase;
}

.project-filter-field select,
.project-filter-field input {
  width: 100%;
  min-height: 44px;
  padding: 11px 13px;
  border: 1px solid var(--border);
  border-radius: 15px;
  background: var(--surface-2);
  color: var(--text);
  font: inherit;
  font-size: 14px;
  transition:
    border-color var(--trans-fast),
    box-shadow var(--trans-fast),
    background var(--trans-fast);
}

.project-filter-field input::placeholder {
  color: color-mix(in srgb, var(--muted) 82%, #fff 18%);
}

.project-filter-field select:focus,
.project-filter-field input:focus {
  outline: none;
  border-color: rgba(12,124,144,.55);
  box-shadow: 0 0 0 4px rgba(12,124,144,.18);
}

.project-filter-actions {
  display: flex;
  gap: 9px;
  align-items: end;
}

.project-search-btn,
.project-reset-btn {
  min-height: 44px;
  padding: 10px 16px;
  box-shadow: none;
  white-space: nowrap;
}

/* Grid */
.projects-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
}

@media (min-width: 700px) {
  .projects-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 1080px) {
  .projects-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

/* Card */
.project-card {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--border);
  border-radius: 24px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.065), rgba(255,255,255,.022)),
    var(--surface);
  box-shadow: 0 14px 38px rgba(16,22,33,.10);
  transition:
    transform var(--trans-slow),
    border-color var(--trans-fast),
    box-shadow var(--trans-slow);
  content-visibility: auto;
  contain-intrinsic-size: 430px;
}

.project-card:hover {
  transform: translateY(-4px);
  border-color: rgba(12,124,144,.42);
  box-shadow: 0 18px 48px rgba(0,0,0,.16);
}

/* Image */
.project-media {
  position: relative;
  display: block;
  overflow: hidden;
  background: var(--surface-2);
}

.project-media img {
  width: 100%;
  aspect-ratio: 16 / 10.4;
  object-fit: cover;
  transform: scale(1.01);
  transition:
    transform var(--trans-slow),
    filter var(--trans-slow);
}

.project-card:hover .project-media img {
  transform: scale(1.045);
  filter: saturate(1.04);
}

.project-media::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(180deg, rgba(0,0,0,.04), rgba(0,0,0,.42)),
    linear-gradient(135deg, rgba(26,44,85,.18), transparent 45%);
}

/* Badges */
.project-status-pill,
.project-progress-chip {
  position: absolute;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  width: fit-content;
  max-width: calc(100% - 24px);
  min-height: 30px;
  padding: 7px 11px;
  border: 1px solid rgba(255,255,255,.26);
  border-radius: 999px;
  background: rgba(15,26,42,.78);
  color: #fff;
  backdrop-filter: blur(10px);
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
}

.project-status-pill {
  left: 12px;
  top: 12px;
}

.project-progress-chip {
  right: 12px;
  bottom: 12px;
  background: rgba(12,124,144,.82);
}

/* Body */
.project-card-body {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 16px;
}

.project-meta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  color: var(--muted);
  font-size: 12.5px;
  line-height: 1.35;
}

.project-meta-row span {
  display: inline-flex;
  align-items: center;
  gap: 7px;
}

.project-meta-row span::before {
  content: "";
  width: 7px;
  height: 7px;
  flex: 0 0 7px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 0 4px rgba(12,124,144,.12);
}

.project-title {
  margin: 0;
  color: var(--text);
  font-size: 20px;
  line-height: 1.22;
  letter-spacing: -.018em;
  font-weight: 900;
}

.project-title a {
  color: inherit;
}

.project-title a:hover {
  color: var(--accent);
}

.project-tagline {
  margin: 0;
  color: var(--text);
  font-size: 14.5px;
  line-height: 1.5;
  font-weight: 760;
}

.project-desc {
  display: -webkit-box;
  margin: 0;
  overflow: hidden;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.62;
  -webkit-line-clamp: 3;
  line-clamp: 3;
  -webkit-box-orient: vertical;
}

/* Progress */
.project-progress-wrap {
  display: grid;
  gap: 7px;
  margin-top: 2px;
}

.project-progress-info {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  color: var(--muted);
  font-size: 12.5px;
  line-height: 1;
}

.project-progress-info strong {
  color: var(--text);
  font-weight: 900;
}

.project-progress-track {
  height: 9px;
  overflow: hidden;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: rgba(255,255,255,.075);
}

.project-progress-bar {
  height: 100%;
  border-radius: inherit;
  background:
    linear-gradient(90deg, var(--brand-teal), color-mix(in srgb, var(--brand-teal) 75%, #fff));
  transition: width var(--trans-slow);
}

/* Actions */
.project-card-actions {
  --project-action-min-width: 104px;
  --project-action-max-width: 150px;
  --project-action-height: 40px;
  --project-action-padding: 9px 15px;
  --project-action-font: 13.5px;

  display: flex;
  flex-wrap: wrap;
  gap: 9px;
  align-items: center;
  margin-top: 4px;
}

.project-card-actions .btn {
  flex: 0 0 auto;
  width: auto;
  min-width: var(--project-action-min-width);
  max-width: var(--project-action-max-width);
  min-height: var(--project-action-height);
  padding: var(--project-action-padding);
  box-shadow: none;
  font-size: var(--project-action-font);
  line-height: 1;
}

.project-primary-link {
  background: linear-gradient(135deg, var(--brand-teal), #0a6f80);
}

.project-secondary-link {
  background: transparent;
}

/* Empty state */
.projects-empty-state {
  grid-column: 1 / -1;
  max-width: 760px;
  margin: 0 auto;
  padding: clamp(22px, 3vw, 30px);
  text-align: center;
  border: 1px solid var(--border);
  border-radius: 24px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.065), rgba(255,255,255,.022)),
    var(--surface);
  box-shadow: 0 14px 38px rgba(16,22,33,.10);
}

.projects-empty-state span {
  display: inline-flex;
  width: fit-content;
  margin-bottom: 10px;
  padding: 7px 12px;
  border-radius: 999px;
  background: rgba(12,124,144,.10);
  color: var(--accent);
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.projects-empty-state h3 {
  margin: 0;
  color: var(--text);
  font-size: 20px;
  line-height: 1.2;
  letter-spacing: -.018em;
  font-weight: 900;
}

.projects-empty-state p {
  max-width: 560px;
  margin: 9px auto 16px;
  color: var(--muted);
  font-size: 14.5px;
  line-height: 1.6;
}

/* Mobile */
@media (max-width: 640px) {
  .projects-section {
    padding: 28px 0 38px;
  }

  .projects-header {
    margin-bottom: 20px;
  }

  .projects-heading {
    font-size: clamp(16px, 2vw, 26px);
    letter-spacing: -.007em;
  }

  .projects-subheading {
    font-size: 15px;
    line-height: 1.62;
  }

  .projects-filter-panel {
    padding: 13px;
    border-radius: 20px;
  }

  .project-filter-actions {
    flex-direction: column;
  }

  .project-search-btn,
  .project-reset-btn {
    width: 100%;
  }

  .projects-grid {
    gap: 15px;
  }

  .project-card {
    border-radius: 21px;
  }

  .project-card-body {
    padding: 15px;
  }

  .project-title {
    font-size: 19px;
  }

  .project-card-actions {
    --project-action-min-width: 100px;
    --project-action-max-width: 136px;
    --project-action-height: 36px;
    --project-action-padding: 8px 13px;
    --project-action-font: 13px;

    justify-content: center;
  }
}

/* Very small mobile */
@media (max-width: 420px) {
  .project-status-pill,
  .project-progress-chip {
    font-size: 11.5px;
    min-height: 28px;
    padding: 7px 10px;
  }

  .project-progress-chip {
    left: 12px;
    right: auto;
  }

  .project-card-actions {
    --project-action-min-width: 96px;
    --project-action-max-width: 128px;
    --project-action-height: 35px;
    --project-action-padding: 8px 12px;
    --project-action-font: 12.8px;

    flex-direction: row;
    justify-content: center;
    gap: 8px;
  }
}

/* Light mode */
@media (prefers-color-scheme: light) {
  .projects-section {
    background:
      radial-gradient(circle at 8% 5%, rgba(12,124,144,.09), transparent 30%),
      radial-gradient(circle at 92% 10%, rgba(198,40,40,.045), transparent 28%),
      linear-gradient(180deg, #ffffff, #f5f8fb);
  }

  .projects-filter-panel,
  .project-card,
  .projects-empty-state {
    box-shadow: 0 12px 34px rgba(16,22,33,.085);
  }

  .project-progress-track {
    background: rgba(12,124,144,.08);
  }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  .project-card,
  .project-media img,
  .project-progress-bar {
    transition: none;
  }

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

  .project-card:hover .project-media img {
    transform: scale(1.01);
  }
}
/* =========================================================
   HOME PAGE — Professional Deed Landing Layout
   Used by templates/index.html
   Fast, scoped, reusable, no extra images required
   ========================================================= */

.home-page {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 8% 5%, rgba(12,124,144,.09), transparent 30%),
    radial-gradient(circle at 94% 9%, rgba(198,40,40,.045), transparent 28%),
    linear-gradient(180deg, var(--bg), var(--bg-soft));
}

/* Shared homepage pieces */
.home-kicker {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  margin-bottom: 12px;
  padding: 7px 13px;
  border: 1px solid rgba(12,124,144,.30);
  border-radius: 999px;
  background: rgba(12,124,144,.10);
  color: var(--accent);
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
  letter-spacing: .10em;
  text-transform: uppercase;
}

.home-heading {
  margin: 0;
  color: var(--text);
  font-size: clamp(16px, 2vw, 26px);
  line-height: 1.18;
  letter-spacing: -.007em;
  font-weight: 900;
}

.home-lead {
  max-width: 720px;
  margin: 10px 0 0;
  color: var(--muted);
  font-size: clamp(15px, 1.35vw, 17px);
  line-height: 1.65;
}

.home-section-head {
  max-width: 820px;
  margin: 0 auto 22px;
  text-align: center;
}

.home-section-head .home-lead {
  margin-left: auto;
  margin-right: auto;
}

.home-card,
.home-intro-panel,
.home-cta-card,
.home-testimonial-card,
.home-empty-card {
  border: 1px solid var(--border);
  background:
    linear-gradient(180deg, rgba(255,255,255,.065), rgba(255,255,255,.022)),
    var(--surface);
  box-shadow: 0 14px 38px rgba(16,22,33,.10);
}

/* Intro */
.home-intro-section {
  position: relative;
  padding: clamp(26px, 4vw, 48px) 0;
}

.home-intro-panel {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
  align-items: center;
  padding: clamp(20px, 3vw, 30px);
  border-radius: 26px;
  overflow: hidden;
}

@media (min-width: 900px) {
  .home-intro-panel {
    grid-template-columns: 1.15fr .85fr;
  }
}

.home-intro-copy {
  max-width: 720px;
}

.home-trust-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}

@media (min-width: 540px) {
  .home-trust-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (min-width: 900px) {
  .home-trust-grid {
    grid-template-columns: 1fr;
  }
}

.home-trust-card {
  position: relative;
  overflow: hidden;
  padding: 16px;
  border: 1px solid rgba(12,124,144,.22);
  border-radius: 20px;
  background:
    linear-gradient(135deg, rgba(12,124,144,.12), rgba(198,40,40,.045)),
    rgba(255,255,255,.035);
}

.home-trust-card::after {
  content: "";
  position: absolute;
  right: -38px;
  top: -38px;
  width: 86px;
  height: 86px;
  border-radius: 50%;
  background: rgba(12,124,144,.13);
}

.home-trust-card strong {
  display: block;
  color: var(--text);
  font-size: 22px;
  line-height: 1.1;
  letter-spacing: -.02em;
  font-weight: 950;
}

.home-trust-card span {
  display: block;
  margin-top: 5px;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.45;
}

/* Values */
.home-value-section {
  padding: clamp(28px, 4vw, 50px) 0;
  border-block: 1px solid var(--border);
  background:
    linear-gradient(135deg, rgba(12,124,144,.055), rgba(198,40,40,.025)),
    var(--bg-soft);
}

.home-value-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}

@media (min-width: 820px) {
  .home-value-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.home-card {
  position: relative;
  overflow: hidden;
  min-height: 210px;
  padding: 20px;
  border-radius: 22px;
  transition:
    transform var(--trans-slow),
    border-color var(--trans-fast),
    box-shadow var(--trans-slow);
}

.home-card:hover {
  transform: translateY(-3px);
  border-color: rgba(12,124,144,.40);
  box-shadow: 0 18px 48px rgba(0,0,0,.14);
}

.home-card-icon {
  display: grid;
  place-items: center;
  width: 44px;
  height: 44px;
  border-radius: 15px;
  background: linear-gradient(135deg, var(--brand-navy), var(--brand-teal));
  color: #fff;
  font-size: 12px;
  font-weight: 950;
  box-shadow: 0 10px 22px rgba(12,124,144,.22);
}

.home-card h3 {
  margin: 14px 0 8px;
  color: var(--text);
  font-size: 20px;
  line-height: 1.22;
  letter-spacing: -.018em;
  font-weight: 900;
}

.home-card p {
  margin: 0;
  color: var(--muted);
  font-size: 14.5px;
  line-height: 1.62;
}

/* Homepage projects spacing */
.home-page .projects-section {
  padding-top: clamp(30px, 4vw, 52px);
  padding-bottom: clamp(30px, 4vw, 52px);
}

/* Testimonials */
.home-testimonials-section {
  padding: clamp(30px, 4vw, 54px) 0;
  border-top: 1px solid var(--border);
}

.home-testimonials-track {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(280px, 1fr);
  gap: 15px;
  overflow-x: auto;
  overscroll-behavior-inline: contain;
  scroll-snap-type: inline mandatory;
  padding: 2px 2px 12px;
}

.home-testimonial-card {
  scroll-snap-align: start;
  min-height: 210px;
  margin: 0;
  padding: 18px;
  border-radius: 22px;
}

.home-testimonial-card blockquote {
  position: relative;
  margin: 0;
  color: var(--text);
  font-size: 15px;
  line-height: 1.7;
  font-style: italic;
  font-weight: 650;
}

.home-testimonial-card figcaption {
  display: grid;
  gap: 2px;
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid var(--border);
}

.home-testimonial-card strong {
  color: var(--text);
  font-size: 14.5px;
  font-weight: 900;
}

.home-testimonial-card span {
  color: var(--muted);
  font-size: 13px;
}

.home-testimonial-card small {
  width: fit-content;
  margin-top: 5px;
  padding: 5px 9px;
  border-radius: 999px;
  background: rgba(12,124,144,.10);
  color: var(--accent);
  font-size: 12px;
  font-weight: 850;
}

.home-empty-card {
  grid-column: 1 / -1;
  padding: 22px;
  border-radius: 22px;
  text-align: center;
}

.home-empty-card strong {
  display: block;
  color: var(--text);
  font-size: 16px;
  font-weight: 900;
}

.home-empty-card p {
  margin: 7px 0 0;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.6;
}

/* CTA */
.home-cta-section {
  padding: clamp(28px, 4vw, 50px) 0;
}

.home-cta-card {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
  align-items: center;
  padding: clamp(20px, 3vw, 30px);
  border-radius: 26px;
  background:
    linear-gradient(135deg, rgba(26,44,85,.94), rgba(12,124,144,.82));
}

.home-cta-card .home-kicker {
  border-color: rgba(255,255,255,.25);
  background: rgba(255,255,255,.12);
  color: #fff;
}

.home-cta-card .home-heading {
  color: #fff;
}

.home-cta-card .home-lead {
  color: rgba(255,255,255,.82);
}

.home-cta-btn {
  justify-self: start;
  min-height: 42px;
  padding: 10px 18px;
  background: #fff;
  color: #102033;
  box-shadow: none;
}

.home-cta-btn:hover {
  color: #102033;
}

@media (min-width: 820px) {
  .home-cta-card {
    grid-template-columns: 1fr auto;
  }

  .home-cta-btn {
    justify-self: end;
  }
}

/* Mobile */
@media (max-width: 640px) {
  .home-intro-section,
  .home-value-section,
  .home-testimonials-section,
  .home-cta-section {
    padding: 28px 0;
  }

  .home-heading {
    font-size: clamp(16px, 2vw, 26px);
    letter-spacing: -.007em;
  }

  .home-lead {
    font-size: 15px;
    line-height: 1.62;
  }

  .home-intro-panel,
  .home-cta-card {
    border-radius: 22px;
    padding: 18px;
  }

  .home-card {
    min-height: auto;
    padding: 18px;
    border-radius: 20px;
  }

  .home-testimonials-track {
    grid-auto-columns: minmax(260px, 88vw);
  }

  .home-cta-btn {
    justify-self: center;
    width: auto;
    max-width: 230px;
  }
}

/* Light mode */
@media (prefers-color-scheme: light) {
  .home-page {
    background:
      radial-gradient(circle at 8% 5%, rgba(12,124,144,.075), transparent 30%),
      radial-gradient(circle at 94% 9%, rgba(198,40,40,.035), transparent 28%),
      linear-gradient(180deg, #ffffff, #f5f8fb);
  }

  .home-card,
  .home-intro-panel,
  .home-cta-card,
  .home-testimonial-card,
  .home-empty-card {
    box-shadow: 0 12px 34px rgba(16,22,33,.085);
  }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  .home-card {
    transition: none;
  }

  .home-card:hover {
    transform: none;
  }
}
/* =========================================================
   ASSOCIATED BUSINESS DETAIL PAGE
   Fast, scoped, professional Deed design
   ========================================================= */

.associated-detail-page {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 8% 4%, rgba(12,124,144,.11), transparent 30%),
    radial-gradient(circle at 92% 8%, rgba(198,40,40,.055), transparent 28%),
    linear-gradient(180deg, var(--bg), var(--bg-soft));
  color: var(--text);
}

.associated-detail-page::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(12,124,144,.032) 1px, transparent 1px),
    linear-gradient(90deg, rgba(12,124,144,.032) 1px, transparent 1px);
  background-size: 46px 46px;
  opacity: .32;
}

.associated-hero,
.associated-section {
  position: relative;
  z-index: 1;
}

.associated-hero {
  padding: clamp(34px, 5vw, 70px) 0;
  border-bottom: 1px solid var(--border);
}

.associated-hero-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(22px, 4vw, 46px);
  align-items: center;
}

@media (min-width: 900px) {
  .associated-hero-grid {
    grid-template-columns: minmax(0, 1fr) 420px;
  }
}

.associated-kicker,
.associated-small-label {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  padding: 7px 13px;
  border: 1px solid rgba(12,124,144,.30);
  border-radius: 999px;
  background: rgba(12,124,144,.10);
  color: var(--accent);
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
  letter-spacing: .10em;
  text-transform: uppercase;
}

.associated-heading,
.associated-section-head h2,
.associated-info-card h2 {
  margin: 12px 0 0;
  color: var(--text);
  font-size: clamp(16px, 2vw, 26px);
  line-height: 1.18;
  letter-spacing: -.007em;
  font-weight: 900;
}

.associated-lead {
  max-width: 720px;
  margin: 12px 0 0;
  color: var(--muted);
  font-size: clamp(15px, 1.35vw, 17px);
  line-height: 1.68;
}

.associated-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}

.associated-actions .btn {
  min-height: 40px;
  padding: 9px 16px;
  box-shadow: none;
  font-size: 13.5px;
}

.associated-primary-btn {
  background: linear-gradient(135deg, var(--brand-teal), #0a6f80);
}

.associated-secondary-btn {
  background: transparent;
}

/* Logo visual */
.associated-visual {
  position: relative;
}

.associated-logo-card {
  display: grid;
  place-items: center;
  min-height: 280px;
  padding: clamp(22px, 4vw, 38px);
  border: 1px solid rgba(12,124,144,.26);
  border-radius: 28px;
  background:
    linear-gradient(135deg, rgba(26,44,85,.92), rgba(12,124,144,.72));
  box-shadow: 0 18px 52px rgba(0,0,0,.16);
}

.associated-logo-card img {
  width: min(100%, 320px);
  max-height: 210px;
  object-fit: contain;
}

/* Main content */
.associated-section {
  padding: clamp(30px, 4vw, 54px) 0;
}

.associated-content-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
}

@media (min-width: 980px) {
  .associated-content-grid {
    grid-template-columns: minmax(0, 1fr) 340px;
    align-items: start;
  }
}

.associated-main-card,
.associated-info-card,
.associated-mini-card,
.associated-feature-card {
  border: 1px solid var(--border);
  border-radius: 24px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.065), rgba(255,255,255,.022)),
    var(--surface);
  box-shadow: 0 14px 38px rgba(16,22,33,.10);
}

.associated-main-card {
  padding: clamp(18px, 3vw, 28px);
  content-visibility: auto;
  contain-intrinsic-size: 560px;
}

.associated-section-head {
  margin: 0 0 14px;
}

.associated-main-card > p {
  margin: 0;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.68;
}

.associated-feature-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  margin-top: 18px;
}

@media (min-width: 760px) {
  .associated-feature-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.associated-feature-card {
  position: relative;
  overflow: hidden;
  padding: 16px;
  border-radius: 18px;
}

.associated-feature-card span {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 12px;
  background: linear-gradient(135deg, var(--brand-navy), var(--brand-teal));
  color: #fff;
  font-size: 12px;
  font-weight: 900;
}

.associated-feature-card strong {
  display: block;
  margin-top: 12px;
  color: var(--text);
  font-size: 15px;
  line-height: 1.25;
  font-weight: 900;
}

.associated-feature-card p {
  margin: 7px 0 0;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.58;
}

/* Sidebar */
.associated-side {
  display: grid;
  gap: 14px;
}

@media (min-width: 980px) {
  .associated-side {
    position: sticky;
    top: 96px;
  }
}

.associated-info-card,
.associated-mini-card {
  padding: 18px;
  content-visibility: auto;
  contain-intrinsic-size: 240px;
}

.associated-info-card {
  background:
    linear-gradient(135deg, rgba(26,44,85,.94), rgba(12,124,144,.78));
  color: #fff;
}

.associated-info-card .associated-small-label {
  color: #fff;
  border-color: rgba(255,255,255,.24);
  background: rgba(255,255,255,.12);
}

.associated-info-card h2 {
  color: #fff;
}

.associated-info-card p {
  margin: 10px 0 16px;
  color: rgba(255,255,255,.84);
  font-size: 14.5px;
  line-height: 1.62;
}

.associated-side-btn {
  min-height: 38px;
  padding: 9px 16px;
  background: #fff;
  color: #122135;
  box-shadow: none;
  font-size: 13.5px;
}

.associated-mini-card strong {
  display: block;
  color: var(--text);
  font-size: 15.5px;
  line-height: 1.2;
  font-weight: 900;
}

.associated-mini-card ul {
  display: grid;
  gap: 9px;
  margin: 14px 0 0;
  padding: 0;
  list-style: none;
}

.associated-mini-card li {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding-top: 9px;
  border-top: 1px solid var(--border);
}

.associated-mini-card span {
  color: var(--muted);
  font-size: 13px;
}

.associated-mini-card b {
  color: var(--text);
  font-size: 13px;
  text-align: right;
}

/* Mobile */
@media (max-width: 640px) {
  .associated-hero {
    padding: 30px 0 38px;
  }

  .associated-heading,
  .associated-section-head h2,
  .associated-info-card h2 {
    font-size: clamp(16px, 2vw, 26px);
    letter-spacing: -.007em;
  }

  .associated-lead,
  .associated-main-card > p {
    font-size: 14.5px;
    line-height: 1.62;
  }

  .associated-logo-card {
    min-height: 220px;
    border-radius: 22px;
  }

  .associated-logo-card img {
    max-height: 160px;
  }

  .associated-actions {
    justify-content: center;
  }

  .associated-actions .btn {
    flex: 0 0 auto;
    width: auto;
    min-width: 128px;
    max-width: 170px;
    min-height: 37px;
    padding: 8px 13px;
    font-size: 13px;
  }

  .associated-section {
    padding: 28px 0 38px;
  }

  .associated-main-card,
  .associated-info-card,
  .associated-mini-card {
    border-radius: 20px;
  }

  .associated-main-card {
    padding: 16px;
  }
}

@media (max-width: 420px) {
  .associated-actions {
    flex-direction: row;
  }

  .associated-actions .btn {
    min-width: 116px;
    max-width: 154px;
    min-height: 35px;
    padding: 8px 12px;
    font-size: 12.8px;
  }
}

/* Light mode */
@media (prefers-color-scheme: light) {
  .associated-detail-page {
    background:
      radial-gradient(circle at 8% 4%, rgba(12,124,144,.09), transparent 30%),
      radial-gradient(circle at 92% 8%, rgba(198,40,40,.045), transparent 28%),
      linear-gradient(180deg, #ffffff, #f5f8fb);
  }

  .associated-main-card,
  .associated-info-card,
  .associated-mini-card,
  .associated-feature-card {
    box-shadow: 0 12px 34px rgba(16,22,33,.085);
  }
}
/* =========================================================
   ASSOCIATED BUSINESS INDEX PAGE
   Fast, scoped, professional Deed design
   Used by associated business index.html
   ========================================================= */

.associate-index-page {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 8% 4%, rgba(12,124,144,.11), transparent 30%),
    radial-gradient(circle at 92% 8%, rgba(198,40,40,.055), transparent 28%),
    linear-gradient(180deg, var(--bg), var(--bg-soft));
  color: var(--text);
}

.associate-index-page::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(12,124,144,.032) 1px, transparent 1px),
    linear-gradient(90deg, rgba(12,124,144,.032) 1px, transparent 1px);
  background-size: 46px 46px;
  opacity: .32;
}

.associate-index-hero,
.associate-index-section {
  position: relative;
  z-index: 1;
}

/* Hero */
.associate-index-hero {
  padding: clamp(34px, 5vw, 70px) 0 clamp(30px, 4vw, 54px);
  border-bottom: 1px solid var(--border);
}

.associate-index-hero-inner {
  max-width: 860px;
  text-align: center;
}

.associate-index-kicker,
.associate-index-small-label {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  padding: 7px 13px;
  border: 1px solid rgba(12,124,144,.30);
  border-radius: 999px;
  background: rgba(12,124,144,.10);
  color: var(--accent);
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
  letter-spacing: .10em;
  text-transform: uppercase;
}

.associate-index-heading,
.associate-index-section-head h2 {
  margin: 12px 0 0;
  color: var(--text);
  font-size: clamp(16px, 2vw, 26px);
  line-height: 1.18;
  letter-spacing: -.007em;
  font-weight: 900;
}

.associate-index-lead,
.associate-index-section-head p {
  max-width: 720px;
  margin: 12px auto 0;
  color: var(--muted);
  font-size: clamp(15px, 1.35vw, 17px);
  line-height: 1.68;
}

.associate-index-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
  margin-top: 18px;
}

.associate-index-actions .btn {
  flex: 0 0 auto;
  width: auto;
  min-height: 40px;
  padding: 9px 16px;
  box-shadow: none;
  font-size: 13.5px;
}

.associate-index-primary-btn {
  background: linear-gradient(135deg, var(--brand-teal), #0a6f80);
}

.associate-index-secondary-btn {
  background: transparent;
}

/* Main section */
.associate-index-section {
  padding: clamp(30px, 4vw, 54px) 0;
}

.associate-index-section-head {
  max-width: 820px;
  margin: 0 auto 22px;
  text-align: center;
}

/* Partial wrapper */
.associate-index-list-shell {
  content-visibility: auto;
  contain-intrinsic-size: 680px;
}

/* Style common card structure inside the partial */
.associate-index-list-shell .cards {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
}

@media (min-width: 700px) {
  .associate-index-list-shell .cards {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 1080px) {
  .associate-index-list-shell .cards {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.associate-index-list-shell .card {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--border);
  border-radius: 24px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.065), rgba(255,255,255,.022)),
    var(--surface);
  box-shadow: 0 14px 38px rgba(16,22,33,.10);
  transition:
    transform var(--trans-slow),
    border-color var(--trans-fast),
    box-shadow var(--trans-slow);
  content-visibility: auto;
  contain-intrinsic-size: 360px;
}

.associate-index-list-shell .card:hover {
  transform: translateY(-4px);
  border-color: rgba(12,124,144,.42);
  box-shadow: 0 18px 48px rgba(0,0,0,.16);
}

.associate-index-list-shell .card-media {
  display: grid;
  place-items: center;
  min-height: 210px;
  padding: 24px;
  background:
    linear-gradient(135deg, rgba(26,44,85,.92), rgba(12,124,144,.72));
}

.associate-index-list-shell .card-media img {
  width: min(100%, 230px);
  max-height: 150px;
  object-fit: contain;
  aspect-ratio: auto;
}

.associate-index-list-shell .card-body {
  padding: 16px;
}

.associate-index-list-shell .card-body h3,
.associate-index-list-shell .card-body .h4 {
  margin: 0;
  color: var(--text);
  font-size: 20px;
  line-height: 1.22;
  letter-spacing: -.018em;
  font-weight: 900;
}

.associate-index-list-shell .card-body p {
  display: -webkit-box;
  margin: 9px 0 0;
  overflow: hidden;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.62;
  -webkit-line-clamp: 3;
  line-clamp: 3;
  -webkit-box-orient: vertical;
}

.associate-index-list-shell .card-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 9px;
  margin-top: 14px;
}

.associate-index-list-shell .card-actions .btn {
  flex: 0 0 auto;
  width: auto;
  min-width: 104px;
  max-width: 150px;
  min-height: 38px;
  padding: 8px 13px;
  box-shadow: none;
  font-size: 13px;
}

/* Mobile */
@media (max-width: 640px) {
  .associate-index-hero {
    padding: 30px 0 38px;
  }

  .associate-index-heading,
  .associate-index-section-head h2 {
    font-size: clamp(16px, 2vw, 26px);
    letter-spacing: -.007em;
  }

  .associate-index-lead,
  .associate-index-section-head p {
    font-size: 14.5px;
    line-height: 1.62;
  }

  .associate-index-actions .btn {
    min-width: 128px;
    max-width: 170px;
    min-height: 37px;
    padding: 8px 13px;
    font-size: 13px;
  }

  .associate-index-section {
    padding: 28px 0 38px;
  }

  .associate-index-list-shell .cards {
    gap: 15px;
  }

  .associate-index-list-shell .card {
    border-radius: 20px;
  }

  .associate-index-list-shell .card-media {
    min-height: 180px;
    padding: 20px;
  }

  .associate-index-list-shell .card-media img {
    max-height: 130px;
  }

  .associate-index-list-shell .card-body {
    padding: 15px;
  }

  .associate-index-list-shell .card-actions .btn {
    min-width: 98px;
    max-width: 132px;
    min-height: 35px;
    padding: 8px 12px;
    font-size: 12.8px;
  }
}

@media (max-width: 420px) {
  .associate-index-actions {
    flex-direction: row;
  }

  .associate-index-actions .btn {
    min-width: 116px;
    max-width: 154px;
  }

  .associate-index-list-shell .card-actions {
    flex-direction: row;
  }
}

/* Light mode */
@media (prefers-color-scheme: light) {
  .associate-index-page {
    background:
      radial-gradient(circle at 8% 4%, rgba(12,124,144,.09), transparent 30%),
      radial-gradient(circle at 92% 8%, rgba(198,40,40,.045), transparent 28%),
      linear-gradient(180deg, #ffffff, #f5f8fb);
  }

  .associate-index-list-shell .card {
    box-shadow: 0 12px 34px rgba(16,22,33,.085);
  }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  .associate-index-list-shell .card {
    transition: none;
  }

  .associate-index-list-shell .card:hover {
    transform: none;
  }
}

/* =========================================================
   PROJECT DETAIL PAGE — Final Responsive Gallery + At a Glance
   Used by templates/projects/detail.html
   Clean block: replaces old duplicated Project Facts / Summary / Visual CSS
   ========================================================= */

.project-detail-page {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 8% 4%, rgba(12,124,144,.10), transparent 30%),
    radial-gradient(circle at 92% 8%, rgba(198,40,40,.05), transparent 28%),
    linear-gradient(180deg, var(--bg), var(--bg-soft));
  color: var(--text);
}

.project-detail-page::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(12,124,144,.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(12,124,144,.03) 1px, transparent 1px);
  background-size: 46px 46px;
  opacity: .30;
}

.project-detail-page > * {
  position: relative;
  z-index: 1;
}

.project-detail-container {
  width: min(1160px, 92vw);
}

/* Hero */
.project-detail-hero {
  position: relative;
  min-height: clamp(360px, 58vh, 560px);
  overflow: hidden;
  display: grid;
  align-items: end;
  border-bottom: 1px solid var(--border);
  isolation: isolate;
}

.project-detail-hero-media {
  position: absolute;
  inset: 0;
  z-index: -2;
  background: var(--surface-2);
}

.project-detail-hero-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  filter: saturate(1.03) contrast(1.02);
}

.project-detail-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    linear-gradient(180deg, rgba(11,18,32,.28), rgba(11,18,32,.76)),
    linear-gradient(90deg, rgba(26,44,85,.70), rgba(12,124,144,.24));
}

.project-detail-hero-content {
  max-width: 850px;
  margin-bottom: clamp(34px, 7vw, 72px);
}

.project-detail-kicker,
.project-detail-small-label {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  padding: 7px 13px;
  border: 1px solid rgba(12,124,144,.34);
  border-radius: 999px;
  background: rgba(12,124,144,.12);
  color: var(--accent);
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
  letter-spacing: .10em;
  text-transform: uppercase;
}

.project-detail-hero .project-detail-kicker {
  color: #fff;
  border-color: rgba(255,255,255,.26);
  background: rgba(255,255,255,.13);
}

.project-detail-heading,
.project-detail-section-head h2,
.project-visual-card strong,
.project-visit-card h2,
.project-related-header h2 {
  color: var(--text);
  font-size: clamp(16px, 2vw, 26px);
  line-height: 1.18;
  letter-spacing: -.007em;
  font-weight: 900;
}

.project-detail-heading {
  margin: 12px 0 0;
  color: #fff;
}

.project-detail-lead {
  max-width: 720px;
  margin: 12px 0 0;
  color: rgba(255,255,255,.86);
  font-size: clamp(15px, 1.35vw, 17px);
  line-height: 1.65;
}

.project-detail-meta,
.project-detail-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 16px;
}

.project-detail-meta span {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 8px 12px;
  border: 1px solid rgba(255,255,255,.22);
  border-radius: 999px;
  background: rgba(255,255,255,.11);
  color: #fff;
  font-size: 13px;
  font-weight: 850;
  line-height: 1;
  backdrop-filter: blur(10px);
}

.project-detail-hero-actions .btn {
  min-height: 40px;
  padding: 9px 16px;
  box-shadow: none;
  font-size: 13.5px;
}

.project-detail-primary-btn,
.project-related-btn:first-child,
.project-link-pill {
  background: linear-gradient(135deg, var(--brand-teal), #0a6f80);
  color: #fff;
}

.project-detail-light-btn {
  color: #fff;
  border-color: rgba(255,255,255,.28);
  background: rgba(255,255,255,.10);
}

/* Main card */
.project-detail-section,
.project-related-section {
  padding: clamp(30px, 4vw, 54px) 0;
}

.project-detail-card {
  max-width: 1120px;
  margin: 0 auto;
  padding: clamp(18px, 2.8vw, 28px);
  border: 1px solid var(--border);
  border-radius: 26px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.060), rgba(255,255,255,.020)),
    var(--surface);
  box-shadow: 0 18px 50px rgba(16,22,33,.12);
}

.project-detail-section-head {
  margin: 0 0 14px;
}

.project-detail-section-head h2 {
  margin: 11px 0 0;
}

.project-detail-desc {
  margin: 0;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.68;
}

/* Gallery + side cards */
.project-showcase {
  display: grid;
  grid-template-columns: minmax(320px, 520px) minmax(300px, 390px);
  justify-content: center;
  gap: 18px;
  align-items: start;
  margin: 20px auto 24px;
  max-width: 940px;
}

.project-gallery-card,
.project-visual-card,
.project-visit-card,
.project-info-board,
.project-related-card {
  border: 1px solid var(--border);
  background:
    linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.018)),
    var(--surface-2);
  box-shadow: 0 14px 34px rgba(16,22,33,.08);
}

.project-gallery-card {
  overflow: hidden;
  border-radius: 24px;
}

.project-gallery-main {
  display: grid;
  place-items: start center;
  align-content: start;
  height: clamp(520px, 48vw, 680px);
  overflow: hidden;
  padding: 10px;
  background:
    linear-gradient(135deg, rgba(12,124,144,.08), rgba(26,44,85,.05)),
    var(--surface-2);
}

.project-gallery-main img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: top center;
  border-radius: 16px;
  background: transparent;
  transform: none;
  transition: filter var(--trans-slow);
}

.project-gallery-card:hover .project-gallery-main img {
  transform: none;
  filter: saturate(1.03);
}

.project-gallery-thumbs {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding: 10px;
  background: rgba(12,124,144,.055);
  scrollbar-width: thin;
}

.project-gallery-thumb {
  flex: 0 0 104px;
  height: 66px;
  padding: 0;
  overflow: hidden;
  cursor: pointer;
  border: 2px solid transparent;
  border-radius: 12px;
  background: transparent;
  opacity: .76;
  transition: opacity var(--trans-fast), border-color var(--trans-fast), transform var(--trans-fast);
}

.project-gallery-thumb:hover,
.project-gallery-thumb.is-active {
  opacity: 1;
  border-color: var(--accent);
  transform: translateY(-1px);
}

.project-gallery-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.project-showcase-side {
  display: grid;
  grid-template-rows: auto auto auto;
  align-content: start;
  align-items: start;
  gap: 16px;
}

.project-visual-card,
.project-visit-card {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  width: 100%;
  border-radius: 22px;
  padding: 20px;
}

.project-visual-card strong {
  display: block;
  margin: 11px 0 10px;
}

.project-visual-card p,
.project-visit-card p,
.project-related-header p {
  margin: 0;
  color: var(--muted);
  font-size: 14.5px;
  line-height: 1.65;
}

.project-visit-card {
  color: #fff;
  background: linear-gradient(135deg, rgba(26,44,85,.94), rgba(12,124,144,.78));
}

.project-visit-card .project-detail-small-label {
  color: #fff;
  border-color: rgba(255,255,255,.24);
  background: rgba(255,255,255,.13);
}

.project-visit-card h2 {
  margin: 11px 0 10px;
  color: #fff;
}

.project-visit-card p {
  color: rgba(255,255,255,.86);
}

.project-visit-btn {
  width: fit-content;
  min-width: 112px;
  min-height: 38px;
  margin-top: 15px;
  padding: 9px 16px;
  background: #fff;
  color: #122135;
  box-shadow: none;
  font-size: 13px;
}

/* At a Glance */
.project-info-board {
  max-width: 980px;
  margin: 24px auto 0;
  padding: clamp(18px, 2.5vw, 24px);
  border-radius: 24px;
}

.project-info-head {
  margin-bottom: 18px;
}

.project-glance-list {
  display: grid;
  gap: 0;
  margin: 0;
  padding: 0;
}

.project-glance-row {
  display: grid;
  grid-template-columns: minmax(150px, 250px) minmax(0, 1fr);
  gap: clamp(12px, 3vw, 28px);
  align-items: start;
  padding: 12px 0;
  border-bottom: 1px solid var(--border);
}

.project-glance-row:first-child {
  padding-top: 0;
}

.project-glance-row:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}

.project-glance-row dt {
  color: var(--muted);
  font-size: 12.5px;
  font-weight: 900;
  line-height: 1.35;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.project-glance-row dd {
  margin: 0;
  color: var(--text);
  font-size: 14.5px;
  font-weight: 500;
  line-height: 1.55;
  overflow-wrap: anywhere;
}

.project-glance-row--long dd {
  color: var(--muted);
}

.project-glance-row--actions dd {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.project-link-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  min-height: 34px;
  padding: 8px 13px;
  border: 1px solid transparent;
  border-radius: 999px;
  font-size: 12.8px;
  font-weight: 900;
  line-height: 1;
}

.project-link-pill--outline {
  background: transparent;
  color: var(--text);
  border-color: var(--border);
}

.project-info-progress {
  display: grid;
  gap: 9px;
  margin-top: 0;
  padding: 14px 15px;
  border: 1px solid rgba(12,124,144,.28);
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(12,124,144,.10), rgba(198,40,40,.035));
}

.project-detail-progress-info,
.project-related-progress-info {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  color: var(--muted);
  font-size: 12.5px;
  line-height: 1;
}

.project-detail-progress-info strong,
.project-related-progress-info strong {
  color: var(--text);
  font-weight: 900;
}

.project-detail-progress-track,
.project-related-progress-track {
  height: 9px;
  overflow: hidden;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: rgba(255,255,255,.075);
}

.project-detail-progress-bar,
.project-related-progress-bar {
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--brand-teal), color-mix(in srgb, var(--brand-teal) 75%, #fff));
  transition: width var(--trans-slow);
}

/* Related projects */
.project-related-section {
  border-top: 1px solid var(--border);
  background:
    radial-gradient(circle at 8% 0%, rgba(12,124,144,.08), transparent 30%),
    radial-gradient(circle at 92% 8%, rgba(198,40,40,.04), transparent 28%),
    linear-gradient(180deg, var(--bg-soft), var(--bg));
}

.project-related-header {
  max-width: 820px;
  margin: 0 auto 22px;
  text-align: center;
}

.project-related-header h2 {
  margin: 10px 0 0;
}

.project-related-header p {
  max-width: 690px;
  margin: 10px auto 0;
}

.project-related-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
}

@media (min-width: 700px) {
  .project-related-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 1080px) {
  .project-related-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.project-related-card {
  overflow: hidden;
  border-radius: 24px;
  transition: transform var(--trans-slow), border-color var(--trans-fast), box-shadow var(--trans-slow);
  content-visibility: auto;
  contain-intrinsic-size: 420px;
}

.project-related-card:hover {
  transform: translateY(-4px);
  border-color: rgba(12,124,144,.42);
  box-shadow: 0 18px 48px rgba(0,0,0,.16);
}

.project-related-media {
  position: relative;
  display: block;
  overflow: hidden;
  background: var(--surface-2);
}

.project-related-media img {
  width: 100%;
  aspect-ratio: 16 / 10.4;
  object-fit: cover;
  transform: scale(1.01);
  transition: transform var(--trans-slow), filter var(--trans-slow);
}

.project-related-card:hover .project-related-media img {
  transform: scale(1.045);
  filter: saturate(1.04);
}

.project-related-media::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(180deg, rgba(0,0,0,.02), rgba(0,0,0,.36)),
    linear-gradient(135deg, rgba(26,44,85,.14), transparent 46%);
}

.project-related-status {
  position: absolute;
  z-index: 2;
  left: 12px;
  top: 12px;
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 7px 11px;
  border: 1px solid rgba(255,255,255,.26);
  border-radius: 999px;
  background: rgba(15,26,42,.78);
  color: #fff;
  backdrop-filter: blur(10px);
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
}

.project-related-body {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 16px;
}

.project-related-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  color: var(--muted);
  font-size: 12.5px;
  line-height: 1.35;
}

.project-related-meta span {
  display: inline-flex;
  align-items: center;
  gap: 7px;
}

.project-related-meta span::before {
  content: "";
  width: 7px;
  height: 7px;
  flex: 0 0 7px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 0 4px rgba(12,124,144,.12);
}

.project-related-body h3 {
  margin: 0;
  color: var(--text);
  font-size: 19px;
  line-height: 1.22;
  letter-spacing: -.018em;
  font-weight: 900;
}

.project-related-body h3 a:hover {
  color: var(--accent);
}

.project-related-body p {
  display: -webkit-box;
  margin: 0;
  overflow: hidden;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.62;
  -webkit-line-clamp: 3;
  line-clamp: 3;
  -webkit-box-orient: vertical;
}

.project-related-progress {
  display: grid;
  gap: 7px;
}

.project-related-actions {
  --related-action-min: 98px;
  --related-action-max: 140px;
  --related-action-height: 36px;
  --related-action-padding: 8px 13px;
  --related-action-font: 13px;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 9px;
  margin-top: 3px;
}

.project-related-actions .btn,
.project-related-btn {
  flex: 0 0 auto;
  width: auto;
  min-width: var(--related-action-min);
  max-width: var(--related-action-max);
  min-height: var(--related-action-height);
  padding: var(--related-action-padding);
  box-shadow: none;
  font-size: var(--related-action-font);
  line-height: 1;
}

.project-related-footer {
  display: flex;
  justify-content: center;
  margin-top: 20px;
}

.project-related-all-btn {
  min-height: 38px;
  padding: 9px 16px;
  box-shadow: none;
  font-size: 13.5px;
}

/* Responsive */
@media (max-width: 900px) {
  .project-showcase {
    grid-template-columns: 1fr;
    max-width: 100%;
  }

  .project-showcase-side {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto;
  }

  .project-gallery-main {
    height: clamp(340px, 58vw, 460px);
  }
}

@media (max-width: 640px) {
  .project-detail-container {
    width: min(100% - 24px, 1160px);
  }

  .project-detail-hero {
    min-height: 410px;
  }

  .project-detail-hero-content {
    margin-bottom: 28px;
  }

  .project-detail-lead,
  .project-detail-desc,
  .project-visual-card p,
  .project-visit-card p,
  .project-related-header p {
    font-size: 14.5px;
    line-height: 1.62;
  }

  .project-detail-meta span {
    min-height: 31px;
    padding: 7px 10px;
    font-size: 12.5px;
  }

  .project-detail-hero-actions {
    justify-content: center;
  }

  .project-detail-hero-actions .btn {
    flex: 0 0 auto;
    width: auto;
    min-width: 126px;
    max-width: 172px;
    min-height: 37px;
    padding: 8px 13px;
    font-size: 13px;
  }

  .project-detail-section,
  .project-related-section {
    padding: 28px 0 38px;
  }

  .project-detail-card {
    padding: 15px;
    border-radius: 20px;
  }

  .project-showcase {
    gap: 14px;
    margin: 16px 0 20px;
  }

  .project-gallery-card,
  .project-visual-card,
  .project-visit-card,
  .project-info-board,
  .project-related-card {
    border-radius: 18px;
  }

  .project-gallery-main {
    height: clamp(280px, 70vw, 360px);
  }

  .project-gallery-thumb {
    flex-basis: 86px;
    height: 56px;
  }

  .project-visual-card,
  .project-visit-card {
    padding: 17px;
  }

  .project-info-board {
    max-width: 100%;
    margin-top: 20px;
    padding: 16px;
  }

  .project-glance-row {
    grid-template-columns: minmax(92px, 38%) minmax(0, 1fr);
    gap: 10px;
    padding: 11px 0;
  }

  .project-glance-row dt {
    font-size: 11.5px;
  }

  .project-glance-row dd {
    font-size: 13.3px;
    line-height: 1.48;
  }

  .project-related-grid {
    gap: 15px;
  }

  .project-related-body {
    padding: 15px;
  }

  .project-related-actions {
    --related-action-min: 96px;
    --related-action-max: 132px;
    --related-action-height: 35px;
    --related-action-padding: 8px 12px;
    --related-action-font: 12.8px;
  }
}

@media (max-width: 420px) {
  .project-gallery-main {
    height: 260px;
  }

  .project-glance-row {
    grid-template-columns: minmax(86px, 40%) minmax(0, 1fr);
  }

  .project-link-pill {
    min-height: 32px;
    padding: 8px 11px;
    font-size: 12.3px;
  }

  .project-related-status {
    min-height: 28px;
    padding: 7px 10px;
    font-size: 11.5px;
  }
}

@media (prefers-color-scheme: light) {
  .project-detail-page {
    background:
      radial-gradient(circle at 8% 4%, rgba(12,124,144,.09), transparent 30%),
      radial-gradient(circle at 92% 8%, rgba(198,40,40,.045), transparent 28%),
      linear-gradient(180deg, #ffffff, #f5f8fb);
  }

  .project-related-section {
    background:
      radial-gradient(circle at 8% 0%, rgba(12,124,144,.07), transparent 30%),
      radial-gradient(circle at 92% 8%, rgba(198,40,40,.035), transparent 28%),
      linear-gradient(180deg, #f5f8fb, #ffffff);
  }

  .project-detail-card,
  .project-gallery-card,
  .project-visual-card,
  .project-visit-card,
  .project-info-board,
  .project-related-card {
    box-shadow: 0 12px 34px rgba(16,22,33,.085);
  }

  .project-detail-progress-track,
  .project-related-progress-track {
    background: rgba(12,124,144,.08);
  }
}

@media (prefers-reduced-motion: reduce) {
  .project-gallery-main img,
  .project-related-card,
  .project-related-media img,
  .project-detail-progress-bar,
  .project-related-progress-bar {
    transition: none;
  }

  .project-related-card:hover {
    transform: none;
  }

  .project-gallery-card:hover .project-gallery-main img {
    transform: none;
  }

  .project-related-card:hover .project-related-media img {
    transform: scale(1.01);
  }
}