/* ============================================================
   COLUMBINE LANDSCAPES CO — Global Styles
   Homepage + Portfolio Hub + Property Pages + Design Hub
   Last updated: Session 8 — 21 April 2026
   Changes:
     - Widget 8 (Credentials) logo classes migrated to global:
       cl-dh-cred-logo-wrap, cl-dh-cred-logo, cl-dh-cred-divider
     - cl-dh-work2 responsive rules moved from inline widget style
       blocks into the global @media sections (900px + 600px)
     - Stale cl-dh-work-* class references in 900px block replaced
       with correct cl-dh-work2-* names
     - cl-portfolio-footer: added missing 900px breakpoint (2-column)
       to fix footer layout on tablet/mid-width viewports
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;1,9..144,300;1,9..144,400&family=Inter:wght@300;400&display=swap');
/* =============================================
   TOKENS
   ============================================= */
:root {
  --cl-fog:       #FAF8F5;
  --cl-slate:     #2C2830;
  --cl-body:      #4A4840;
  --cl-stone:     #9A9588;
  --cl-border:    #DDD9D2;
  --cl-linen:     #DDD9CF;
  --cl-plum:      #6B2D68;
  --cl-aubergine: #38203A;
  --cl-mauve:     #C4A8C2;
  --cl-sage:      #B8C4A0;
  --cl-gold:      #C9920A;
/* =============================================
   GLOBAL RESETS
   ============================================= */
.elementor-page #page,
.elementor-page .site-content,
.elementor-page #content,
.elementor-page #main {
  margin-top: 0 !important;
  padding-top: 0 !important;
.elementor-page .site-header + .page-content,
.elementor-page #content {
  padding-top: 0 !important;
  margin-top: 0 !important;
.elementor-section-wrap > .elementor-container,
.e-con-inner {
  max-width: 100% !important;
  width: 100% !important;
/* =============================================
   CONTACT PAGE TOKENS
   ============================================= */
.cl-contact {
  --cl-fog:      #FAF8F5;
  --cl-slate:    #2C2830;
  --cl-body:     #4a4840;
  --cl-muted:    #9a9588;
  --cl-border:   #DDD9D2;
  --cl-linen:    #ddd9cf;
  --cl-plum:     #6B2D68;
  --cl-mauve:    #C4A8C2;
  --cl-fraunces: 'Fraunces', Georgia, serif;
  --cl-inter:    'Inter', system-ui, sans-serif;
  background: var(--cl-fog);
  width: 100%;
  font-family: var(--cl-inter);
  color: var(--cl-body);
  display: flex;
  flex-direction: column;
/* =============================================
   CONTACT PAGE 
 NAV
   ============================================= */
.cl-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 74px;
  padding: 0 48px;
  background: var(--cl-fog);
  border-bottom: 0.5px solid var(--cl-border);
  width: 100%;
  box-sizing: border-box;
  flex-shrink: 0;
.cl-nav-logo {
  font-family: var(--cl-fraunces);
  font-size: 17px;
  font-weight: 400;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--cl-slate);
  text-decoration: none;
.cl-nav-links {
  display: flex;
  align-items: center;
  gap: 36px;
  list-style: none;
  margin: 0;
  padding: 0;
.cl-nav-links a {
  font-family: var(--cl-inter);
  font-size: 12px;
  font-weight: 300;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--cl-muted);
  text-decoration: none;
  transition: color 200ms ease;
.cl-nav-links a:hover { color: var(--cl-plum); }
/* =============================================
   CONTACT PAGE 
 BODY
   ============================================= */
.cl-headline {
  font-weight: 300 !important;
.cl-note p {
  font-weight: 300 !important;
.cl-body {
  display: grid;
  grid-template-columns: 1fr 1fr;
  width: 100%;
  flex: 1;
.cl-left {
  background: var(--cl-fog);
  border-right: 0.5px solid var(--cl-border);
  padding: 72px 56px 72px 48px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  box-sizing: border-box;
.cl-eyebrow {
  font-family: var(--cl-inter);
  font-size: 11px;
  font-weight: 400;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--cl-muted);
  margin: 0 0 28px 0;
.cl-contact h1,
.cl-contact h1.cl-headline,
.cl-headline {
  font-family: 'Fraunces', Georgia, serif !important;
  font-size: 52px !important;
  font-weight: 300 !important;
  line-height: 1.15 !important;
  color: #2C2830 !important;
  margin: 0 0 40px 0 !important;
  max-width: 520px;
.cl-headline em {
  font-style: italic !important;
  font-weight: 300 !important;
  color: #6B2D68 !important;
.cl-note {
  font-family: var(--cl-inter);
  font-size: 15px;
  font-weight: 300;
  line-height: 1.85;
  color: var(--cl-body);
  max-width: 420px;
  margin: 0;
.cl-note p { margin: 0; }
.cl-note p + p { margin-top: 18px; }
.cl-signature {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-top: 48px;
.cl-signature-rule {
  width: 32px;
  height: 0.5px;
  background: var(--cl-mauve);
  flex-shrink: 0;
  display: block;
.cl-signature-name {
  font-family: var(--cl-fraunces);
  font-size: 18px;
  font-weight: 300;
  font-style: italic;
  color: var(--cl-plum);
.cl-email-block { margin-top: 52px; }
.cl-email-label {
  font-family: var(--cl-inter);
  font-size: 11px;
  font-weight: 400;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--cl-muted);
  margin: 0 0 10px 0;
.cl-response-note {
  font-family: var(--cl-inter);
  font-size: 12px;
  font-weight: 300;
  color: var(--cl-muted);
  margin: 10px 0 0 0;
.cl-contact-btn {
  background: none;
  border: none;
  border-bottom: 0.5px solid var(--cl-plum);
  cursor: pointer;
  padding: 0 0 2px 0;
  font-family: var(--cl-inter);
  font-size: 11px;
  font-weight: 400;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--cl-plum);
  transition: color 200ms ease, border-color 200ms ease;
.cl-contact-btn:hover {
  color: var(--cl-slate);
  border-bottom-color: var(--cl-slate);
.cl-phone-link {
  color: var(--cl-slate);
  text-decoration: none;
  border-bottom: 0.5px solid var(--cl-border);
  padding-bottom: 1px;
  transition: color 200ms ease;
.cl-phone-link:hover {
  color: var(--cl-plum);
  border-bottom-color: var(--cl-plum);
/* =============================================
   CONTACT PAGE 
 RIGHT PANEL
   ============================================= */
.cl-right {
  background: var(--cl-linen);
  position: relative;
  display: block;
  min-height: 600px;
  overflow: hidden;
.cl-portrait-wrap {
  position: absolute;
  inset: 0;
  bottom: 61px;
  padding: 0;
.cl-portrait {
  width: 100%;
  height: 100%;
  border-radius: 0;
  overflow: hidden;
  border: none;
.cl-portrait img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
.cl-caption {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  background: var(--cl-fog);
  padding: 20px 40px;
  box-sizing: border-box;
  border-top: 0.5px solid var(--cl-border);
.cl-caption-name {
  font-family: var(--cl-fraunces);
  font-size: 18px;
  font-weight: 400;
  color: var(--cl-slate);
  display: block;
  margin: 0;
.cl-caption-title {
  font-family: var(--cl-inter);
  font-size: 11px;
  font-weight: 400;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--cl-muted);
  display: block;
  margin: 4px 0 0 0;
/* =============================================
   CONTACT PAGE 
 FOOTER
   ============================================= */
.cl-footer {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border-top: 0.5px solid var(--cl-border);
  width: 100%;
  box-sizing: border-box;
  flex-shrink: 0;
.cl-footer-cell {
  padding: 24px 48px;
  border-right: 0.5px solid var(--cl-border);
  box-sizing: border-box;
.cl-footer-cell:last-child { border-right: none; }
.cl-footer-label {
  font-family: var(--cl-inter);
  font-size: 11px;
  font-weight: 400;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--cl-muted);
  display: block;
  margin: 0 0 6px 0;
.cl-footer-value {
  font-family: var(--cl-fraunces);
  font-size: 15px;
  font-weight: 300;
  color: var(--cl-slate);
  display: block;
  margin: 0;
/* =============================================
   CONTACT PAGE 
 MODAL
   ============================================= */
.cl-modal {
  position: fixed !important;
  inset: 0 !important;
  z-index: 99999 !important;
  display: flex;
  align-items: center;
  justify-content: center;
.cl-modal-backdrop {
  position: fixed !important;
  inset: 0 !important;
  background: rgba(44, 40, 48, 0.55) !important;
  backdrop-filter: blur(3px) !important;
  z-index: 99999 !important;
.cl-modal-box {
  position: relative !important;
  z-index: 100000 !important;
  background: #FAF8F5 !important;
  border: 0.5px solid #DDD9D2 !important;
  padding: 48px 52px 52px !important;
  width: 100% !important;
  max-width: 520px !important;
  box-sizing: border-box !important;
  margin: 24px !important;
  max-height: 90vh !important;
  overflow-y: auto !important;
.cl-modal-close {
  position: absolute;
  top: 20px;
  right: 24px;
  background: none;
  border: none;
  font-size: 16px;
  color: var(--cl-muted);
  cursor: pointer;
  line-height: 1;
  transition: color 200ms ease;
.cl-modal-close:hover { color: var(--cl-plum); }
.cl-modal-heading { display: none !important; }
.cl-modal-eyebrow {
  font-family: 'Fraunces', Georgia, serif !important;
  font-size: 24px !important;
  font-weight: 300 !important;
  font-style: italic !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  color: #6B2D68 !important;
  margin: 0 0 28px 0 !important;
.cl-modal-box .nf-form-title,
.cl-modal-box .nf-form-content .nf-before-form-content {
  display: none !important;
.cl-modal-box .nf-form-content .label-above .nf-field-label label {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 11px !important;
  font-weight: 400 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  color: #9a9588 !important;
.cl-modal-box .nf-form-content input[type=text],
.cl-modal-box .nf-form-content input[type=email],
.cl-modal-box .nf-form-content input[type=tel],
.cl-modal-box .nf-form-content textarea {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 15px !important;
  font-weight: 300 !important;
  color: #2C2830 !important;
  background: transparent !important;
  border: none !important;
  border-bottom: 0.5px solid #DDD9D2 !important;
  border-radius: 0 !important;
  padding: 8px 0 !important;
  box-shadow: none !important;
  width: 100% !important;
.cl-modal-box .nf-form-content input:focus,
.cl-modal-box .nf-form-content textarea:focus {
  outline: none !important;
  border-bottom-color: #6B2D68 !important;
.cl-modal-box .nf-form-content textarea {
  min-height: 100px !important;
  resize: none !important;
.cl-modal-box .nf-form-content .submit-wrap input[type=button],
.cl-modal-box .nf-form-content .submit-wrap input[type=submit] {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 11px !important;
  font-weight: 400 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  color: #FAF8F5 !important;
  background: #6B2D68 !important;
  border: none !important;
  border-radius: 0 !important;
  padding: 14px 32px !important;
  cursor: pointer !important;
  margin-top: 8px !important;
  transition: background 200ms ease !important;
.cl-modal-box .nf-form-content .submit-wrap input:hover {
  background: #2C2830 !important;
/* =============================================
   HERO
   ============================================= */
.cl-hero {
  position: relative;
  min-height: 600px !important;
  width: 100vw !important;
  max-width: 100vw !important;
  margin-left: calc(-1 * ((100vw - 100%) / 2)) !important;
.cl-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to right,
    rgba(0,0,0,0.82) 0%,
    rgba(0,0,0,0.75) 50%,
    rgba(0,0,0,0.35) 100%
  ),
  linear-gradient(
    to bottom,
    rgba(0,0,0,0.10) 0%,
    rgba(0,0,0,0.70) 100%
  );
  z-index: 1;
.cl-hero-content {
  position: relative;
  z-index: 2;
  max-width: 900px;
  padding: 260px 0 80px 80px !important;
.cl-hero .cl-hero-content .cl-hero-h1 {
  font-family: 'Fraunces', serif !important;
  font-size: 80px !important;
  font-weight: 300 !important;
  color: #ffffff !important;
  line-height: 1.1 !important;
  text-transform: none !important;
  text-shadow: 0 2px 20px rgba(0,0,0,0.5) !important;
  margin-bottom: 16px !important;
  letter-spacing: 0.01em !important;
.cl-hero .cl-hero-content .cl-hero-sub {
  font-family: 'Inter', sans-serif !important;
  font-size: 20px !important;
  font-weight: 300 !important;
  color: rgba(255,255,255,0.85) !important;
  margin-bottom: 32px !important;
  letter-spacing: 0.01em !important;
  text-shadow: 0 1px 12px rgba(0,0,0,0.6) !important;
.cl-hero-cta {
  display: inline-block;
  font-family: 'Inter', sans-serif;
  font-size: 16px;
  font-weight: 500;
  color: #fff;
  border: 1px solid rgba(255,255,255,0.8);
  border-radius: 15px;
  padding: 12px 24px;
  text-decoration: none;
  letter-spacing: 0.01em;
  transition: background 0.2s, color 0.2s;
.cl-hero-cta:hover {
  background: var(--cl-plum);
  border-color: var(--cl-plum);
  color: #fff;
/* =============================================
   SECTION 02 
 POSITIONING
   ============================================= */
.cl-positioning-section {
  background: #FAF8F5;
  padding: 80px 80px;
  box-sizing: border-box;
  width: 100%;
.cl-positioning-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
  max-width: 1200px;
.cl-positioning-text {
  display: flex;
  flex-direction: column;
.cl-positioning-h2 {
  font-family: 'Fraunces', serif !important;
  font-size: 40px !important;
  font-weight: 300 !important;
  color: #2C2830 !important;
  line-height: 1.2 !important;
  margin: 0 0 24px 0 !important;
.cl-positioning-body {
  font-family: 'Inter', sans-serif !important;
  font-size: 18px !important;
  font-weight: 300 !important;
  color: #4A4840 !important;
  line-height: 1.7 !important;
  margin: 0 0 14px 0 !important;
.cl-positioning-body:last-child {
  margin-bottom: 0 !important;
.cl-positioning-image {
  width: 100%;
.cl-positioning-image img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 6px;
/* =============================================
   SECTION 03 
 SELECTED WORK
   ============================================= */
.cl-work-section {
  background: #FAF8F5;
  padding: 80px 80px 96px 80px;
  box-sizing: border-box;
  width: 100%;
.cl-work-inner {
  max-width: 1200px;
.cl-work-title {
  font-family: 'Fraunces', serif !important;
  font-size: 48px !important;
  font-weight: 300 !important;
  color: var(--cl-slate) !important;
  line-height: 1.2 !important;
  margin: 0 0 24px 0 !important;
.cl-work-divider {
  width: 100%;
  max-width: 480px;
  height: 1px;
  background-color: var(--cl-border);
  margin-bottom: 48px;
.cl-featured-project {
  margin-bottom: 48px;
.cl-featured-image {
  width: 100% !important;
  height: 520px !important;
  object-fit: cover !important;
  object-position: center !important;
  border-radius: 6px !important;
  display: block !important;
  margin-bottom: 16px !important;
.cl-secondary-projects {
  display: flex;
  gap: 48px;
.cl-project-card {
  flex: 1;
.cl-secondary-image {
  width: 100% !important;
  aspect-ratio: 4 / 3 !important;
  object-fit: cover !important;
  display: block !important;
  border-radius: 6px !important;
  margin-bottom: 14px !important;
.cl-project-link {
  text-decoration: none !important;
  color: inherit !important;
  display: block !important;
.cl-project-name {
  font-family: 'Fraunces', serif !important;
  font-size: 24px !important;
  font-weight: 300 !important;
  color: var(--cl-slate) !important;
  line-height: 1.2 !important;
  margin: 0 0 6px 0 !important;
.cl-project-location {
  font-family: 'Inter', sans-serif !important;
  font-size: 15px !important;
  font-weight: 300 !important;
  color: var(--cl-stone) !important;
  line-height: 1.4 !important;
  margin: 0 !important;
/* =============================================
   SECTION 05 
 DESIGN PHILOSOPHY
   ============================================= */
.cl-philosophy-section {
  background: #FAF8F5;
  padding: 80px 80px 96px 80px;
  box-sizing: border-box;
  width: 100%;
.cl-philosophy-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: start;
  max-width: 1200px;
.cl-philosophy-text {
  display: flex;
  flex-direction: column;
.cl-philosophy-title {
  font-family: 'Fraunces', serif !important;
  font-size: 48px !important;
  font-weight: 300 !important;
  color: #2C2830 !important;
  line-height: 1.2 !important;
  margin: 0 0 20px 0 !important;
.cl-philosophy-intro {
  font-family: 'Inter', sans-serif !important;
  font-size: 18px !important;
  font-weight: 300 !important;
  color: #4A4840 !important;
  line-height: 1.7 !important;
  margin: 0 0 16px 0 !important;
.cl-philosophy-body {
  font-family: 'Inter', sans-serif !important;
  font-size: 15px !important;
  font-weight: 300 !important;
  color: #4A4840 !important;
  line-height: 1.85 !important;
  margin: 0 0 14px 0 !important;
.cl-philosophy-body:last-of-type {
  margin-bottom: 0 !important;
.cl-philosophy-link {
  display: inline-block !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 13px !important;
  font-weight: 300 !important;
  color: var(--cl-plum) !important;
  text-decoration: none !important;
  border-bottom: 0.5px solid transparent !important;
  padding-bottom: 1px !important;
  margin-top: 24px !important;
  letter-spacing: 0.02em !important;
  transition: border-color 200ms ease, color 200ms ease;
.cl-philosophy-link:hover {
  border-bottom-color: var(--cl-plum) !important;
  color: var(--cl-aubergine) !important;
.cl-philosophy-image {
  width: 100%;
.cl-philosophy-image img {
  width: 100% !important;
  height: 560px !important;
  object-fit: cover !important;
  object-position: center center !important;
  border-radius: 6px !important;
  display: block !important;
/* =============================================
   SECTION 06 
 SERVICES
   ============================================= */
.cl-services {
  background: var(--cl-linen);
  padding: 80px 80px 88px 80px;
  box-sizing: border-box;
  width: 100%;
.cl-services-eyebrow {
  font-family: 'Inter', sans-serif !important;
  font-size: 11px !important;
  font-weight: 400 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  color: var(--cl-stone) !important;
  margin: 0 0 20px 0 !important;
.cl-services-title {
  font-family: 'Fraunces', serif !important;
  font-size: 48px !important;
  font-weight: 300 !important;
  color: var(--cl-slate) !important;
  line-height: 1.2 !important;
  margin: 0 0 24px 0 !important;
.cl-services-intro {
  font-family: 'Inter', sans-serif !important;
  font-size: 18px !important;
  font-weight: 300 !important;
  color: var(--cl-body) !important;
  line-height: 1.6 !important;
  max-width: 860px !important;
  margin: 0 !important;
.cl-services-divider {
  width: 100%;
  height: 0.5px;
  background: var(--cl-border);
  margin: 32px 0 16px 0;
.cl-services-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 48px;
.cl-service-card {
  display: flex;
  flex-direction: column;
.cl-service-number {
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  font-weight: 400;
  letter-spacing: 0.18em;
  color: var(--cl-stone);
  margin-bottom: 16px;
  display: block;
.cl-service-name {
  font-family: 'Fraunces', serif !important;
  font-size: 28px !important;
  font-weight: 300 !important;
  color: var(--cl-slate) !important;
  line-height: 1.2 !important;
  margin: 0 0 16px 0 !important;
.cl-service-body {
  font-family: 'Inter', sans-serif !important;
  font-size: 15px !important;
  font-weight: 300 !important;
  color: var(--cl-body) !important;
  line-height: 1.75 !important;
  margin: 0 0 24px 0 !important;
  flex: 1;
.cl-service-link {
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  font-weight: 400;
  letter-spacing: 0.04em;
  color: var(--cl-plum);
  text-decoration: none;
  border-bottom: 0.5px solid transparent;
  padding-bottom: 1px;
  transition: border-color 200ms ease, color 200ms ease;
  align-self: flex-start;
.cl-service-link:hover {
  border-bottom-color: var(--cl-plum);
  color: var(--cl-aubergine);
/* =============================================
   SECTION 07 
 CTA
   ============================================= */
.cl-cta {
  background: var(--cl-aubergine);
  padding: 96px 80px;
  box-sizing: border-box;
  width: 100%;
.cl-cta-eyebrow {
  font-family: 'Inter', sans-serif !important;
  font-size: 11px !important;
  font-weight: 400 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  color: var(--cl-mauve) !important;
  margin: 0 0 24px 0 !important;
.cl-cta-title {
  font-family: 'Fraunces', serif !important;
  font-size: 56px !important;
  font-weight: 300 !important;
  color: var(--cl-fog) !important;
  line-height: 1.15 !important;
  max-width: 720px !important;
  margin: 0 0 24px 0 !important;
.cl-cta-body {
  font-family: 'Inter', sans-serif !important;
  font-size: 18px !important;
  font-weight: 300 !important;
  color: rgba(250, 248, 245, 0.70) !important;
  line-height: 1.65 !important;
  max-width: 640px !important;
  margin: 0 0 40px 0 !important;
.cl-cta-btn {
  display: inline-block;
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  font-weight: 400;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #ffffff;
  background: var(--cl-plum);
  border: none;
  border-radius: 15px;
  padding: 14px 32px;
  text-decoration: none;
  transition: background 200ms ease, color 200ms ease;
.cl-cta-btn:hover {
  background: var(--cl-fog);
  color: var(--cl-aubergine);
/* ============================================================
   PORTFOLIO HUB PAGE 
 /design/portfolio/
   ============================================================ */
.page-portfolio .container,
.page-portfolio .container_inner,
.page-portfolio .default_template_holder {
  max-width: 100% !important;
  width: 100% !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
.page-portfolio,
.page-portfolio #page,
.page-portfolio #content,
.page-portfolio .site-content,
.page-portfolio .elementor-section,
.page-portfolio .e-con,
.page-portfolio .elementor-column,
.page-portfolio .elementor-widget-wrap {
  background-color: #FAF8F5 !important;
.page-portfolio .qodef-title-holder,
.page-portfolio .qodef-page-title,
.page-portfolio #qodef-page-title,
.page-portfolio .qodef-content-top-area {
  display: none !important;
  height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
.cl-portfolio-intro-section {
  padding: 24px 0 40px 0 !important;
  background-color: #FAF8F5 !important;
.cl-portfolio-intro-section .cl-portfolio {
  padding-left: 80px !important;
  padding-right: 80px !important;
.cl-portfolio-intro-section .elementor-widget-container,
.cl-portfolio-intro-section .elementor-widget-wrap,
.cl-portfolio-intro-section .elementor-column-wrap > .elementor-widget-wrap {
  padding: 0 !important;
.cl-portfolio .cl-eyebrow {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 11px !important;
  font-weight: 400 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  color: #9A9588 !important;
  display: block !important;
  margin: 0 0 24px 0 !important;
.cl-portfolio h1,
.cl-portfolio h1.cl-headline,
.cl-portfolio .cl-headline {
  font-family: 'Fraunces', Georgia, serif !important;
  font-size: 48px !important;
  font-weight: 300 !important;
  line-height: 1.15 !important;
  color: #2C2830 !important;
  margin: 0 0 28px 0 !important;
  max-width: 560px;
  text-transform: none !important;
  letter-spacing: 0 !important;
.cl-portfolio h1 em,
.cl-portfolio .cl-headline em {
  font-family: 'Fraunces', Georgia, serif !important;
  font-style: italic !important;
  font-weight: 300 !important;
  color: #6B2D68 !important;
.cl-portfolio .cl-portfolio-intro-body {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 15px !important;
  font-weight: 300 !important;
  line-height: 1.85 !important;
  color: #4A4840 !important;
  max-width: 780px;
  margin-top: 0 !important;
  margin-bottom: 0 !important;
.cl-portfolio .cl-portfolio-intro-body p {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 15px !important;
  font-weight: 300 !important;
  line-height: 1.85 !important;
  color: #4A4840 !important;
  margin: 0 !important;
  padding-bottom: 18px !important;
.cl-portfolio a.cl-portfolio-cta {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 11px !important;
  font-weight: 400 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  color: #6B2D68 !important;
  text-decoration: none !important;
  border-bottom: 0.5px solid #6B2D68 !important;
  padding-bottom: 2px !important;
  display: inline-block !important;
  background: none !important;
  margin-top: 24px !important;
  transition: color 200ms ease, border-color 200ms ease;
.cl-portfolio a.cl-portfolio-cta:hover {
  color: #38203A !important;
  border-color: #38203A !important;
.cl-portfolio-grid-section {
  padding: 0 0 96px 0 !important;
  background-color: #FAF8F5 !important;
.cl-portfolio-grid-section .cl-portfolio {
  padding-left: 80px !important;
  padding-right: 80px !important;
.cl-portfolio-grid-section .elementor-widget-container,
.cl-portfolio-grid-section .elementor-widget-wrap,
.cl-portfolio-grid-section .elementor-column-wrap > .elementor-widget-wrap {
  padding: 0 !important;
.cl-portfolio .cl-cards {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 0 !important;
  border-top: 0.5px solid #DDD9D2 !important;
  border-left: 0.5px solid #DDD9D2 !important;
.cl-portfolio .cl-card {
  display: block !important;
  text-decoration: none !important;
  background: #FAF8F5 !important;
  border-right: 0.5px solid #DDD9D2 !important;
  border-bottom: 0.5px solid #DDD9D2 !important;
  transition: background 200ms ease;
.cl-portfolio .cl-card:hover {
  background: #F5F2EE !important;
.cl-portfolio .cl-card__img {
  margin: 8px 8px 0 8px !important;
  width: calc(100% - 16px) !important;
  aspect-ratio: 4 / 3 !important;
  background-color: #DDD9CF !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
.cl-portfolio .cl-card__img-label {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 11px !important;
  font-weight: 300 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: #9A9588 !important;
.cl-portfolio .cl-card__body {
  padding: 20px 28px 32px !important;
.cl-portfolio .cl-card__number {
  display: block !important;
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 11px !important;
  font-weight: 300 !important;
  letter-spacing: 0.14em !important;
  color: #9A9588 !important;
  margin-bottom: 10px !important;
.cl-portfolio .cl-card h2,
.cl-portfolio .cl-card h2.cl-card__title,
.cl-portfolio .cl-card__title {
  font-family: 'Fraunces', Georgia, serif !important;
  font-size: 22px !important;
  font-weight: 300 !important;
  line-height: 1.2 !important;
  color: #2C2830 !important;
  margin: 0 0 8px 0 !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
.cl-portfolio .cl-card__tags {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 11px !important;
  font-weight: 300 !important;
  letter-spacing: 0.04em !important;
  color: #9A9588 !important;
  margin: 0 !important;
.cl-portfolio .cl-card__rule {
  border: none !important;
  border-top: 0.5px solid #DDD9D2 !important;
  margin: 20px 0 !important;
.cl-portfolio .cl-card__link {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 11px !important;
  font-weight: 400 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: #6B2D68 !important;
  border-bottom: 0.5px solid #6B2D68 !important;
  padding-bottom: 1px !important;
  text-decoration: none !important;
.cl-portfolio .cl-card:hover .cl-card__link {
  color: #38203A !important;
  border-color: #38203A !important;
.cl-carousel-section .cl-portfolio {
  padding-left: 0 !important;
  padding-right: 0 !important;
.cl-carousel-section .elementor-widget-container {
  padding: 0 !important;
.cl-portfolio .cl-carousel__title {
  font-family: 'Fraunces', Georgia, serif !important;
  font-size: 36px !important;
  font-weight: 300 !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  color: #FAF8F5 !important;
  line-height: 1.15 !important;
.cl-portfolio .cl-carousel__eyebrow {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 10px !important;
  font-weight: 400 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.18em !important;
  color: rgba(250,248,245,0.65) !important;
.cl-search-section .cl-portfolio {
  padding-left: 0 !important;
  padding-right: 0 !important;
.cl-search-section .elementor-widget-container,
.cl-search-section .elementor-widget-wrap,
.cl-search-section .elementor-column-wrap > .elementor-widget-wrap {
  padding: 0 !important;
.cl-portfolio-footer {
  display: grid !important;
  grid-template-columns: 1fr 1fr 1fr !important;
  border-top: 0.5px solid #DDD9D2 !important;
  width: 100% !important;
  box-sizing: border-box !important;
.cl-portfolio-footer__cell {
  padding: 28px 48px !important;
  border-right: 0.5px solid #DDD9D2 !important;
  box-sizing: border-box !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
.cl-portfolio-footer__cell:last-child {
  border-right: none !important;
.cl-portfolio-footer__label {
  font-family: 'Fraunces', Georgia, serif !important;
  font-size: 15px !important;
  font-weight: 300 !important;
  color: #2C2830 !important;
  display: block !important;
.cl-portfolio-footer__sub {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 11px !important;
  font-weight: 300 !important;
  letter-spacing: 0.06em !important;
  color: #9A9588 !important;
  display: block !important;
.cl-portfolio-footer__email {
  font-family: 'Fraunces', Georgia, serif !important;
  font-size: 17px !important;
  font-weight: 400 !important;
  color: #2C2830 !important;
  text-decoration: none !important;
  border-bottom: 0.5px solid transparent !important;
  transition: color 200ms ease, border-color 200ms ease;
.cl-portfolio-footer__email:hover {
  color: #6B2D68 !important;
  border-bottom-color: #6B2D68 !important;
.cl-portfolio-footer__name {
  font-family: 'Fraunces', Georgia, serif !important;
  font-size: 18px !important;
  font-weight: 300 !important;
  font-style: italic !important;
  color: #6B2D68 !important;
  display: block !important;
/* ============================================================
   PROPERTY PAGE 
 SECTION 1: HERO HEADER
   ============================================================ */
.cl-property-hero-section .elementor-widget-container,
.cl-property-body-section .elementor-widget-container,
.cl-property-testimonial-section .elementor-widget-container {
  padding: 0 !important;
.cl-property-hero-section {
  padding: 80px 0 32px 0 !important;
  background-color: #FAF8F5 !important;
.cl-property-hero-section .cl-portfolio {
  padding-left: 80px !important;
  padding-right: 80px !important;
.cl-property-hero-section .elementor-widget-wrap,
.cl-property-hero-section .elementor-column-wrap > .elementor-widget-wrap {
  padding: 0 !important;
.cl-property-breadcrumb {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 24px;
.cl-property-breadcrumb a {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 11px !important;
  font-weight: 300 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  color: #9A9588 !important;
  text-decoration: none !important;
  transition: color 200ms ease;
.cl-property-breadcrumb a:hover {
  color: #6B2D68 !important;
.cl-property-breadcrumb span {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 11px !important;
  font-weight: 300 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  color: #9A9588 !important;
.cl-property-meta {
  margin-bottom: 16px;
.cl-gallery__item img {
  border-radius: 6px;
/* ============================================================
   PROPERTY PAGE 
 SECTION 2: IMAGE GALLERY
   ============================================================ */
.cl-gallery--hero-plus-four {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  grid-template-rows: repeat(2, 1fr);
  gap: 8px;
  height: 640px;
.cl-gallery--hero-plus-four .cl-gallery__item {
  overflow: hidden;
  cursor: pointer;
  min-height: 0;
  aspect-ratio: unset;
.cl-gallery--hero-plus-four .cl-gallery__item:first-child {
  grid-column: 1;
  grid-row: 1 / 3;
.cl-gallery--hero-plus-four .cl-gallery__item:nth-child(2) {
  grid-column: 2;
  grid-row: 1;
.cl-gallery--hero-plus-four .cl-gallery__item:nth-child(3) {
  grid-column: 2;
  grid-row: 2;
.cl-gallery--hero-plus-four .cl-gallery__item:nth-child(4) {
  grid-column: 3;
  grid-row: 1;
.cl-gallery--hero-plus-four .cl-gallery__item:nth-child(5) {
  grid-column: 3;
  grid-row: 2;
.cl-gallery--hero-plus-four .cl-gallery__item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  border-radius: 6px;
.cl-gallery--hero-plus-two {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 6px;
.cl-gallery--hero-plus-two .cl-gallery__item:first-child {
  grid-row: span 2;
.cl-gallery--two-up {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px;
.cl-gallery--three-up {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 6px;
.cl-gallery--hero-only {
  display: block;
.cl-gallery--two-portrait {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px;
.cl-gallery__item {
  overflow: hidden;
  background: #DDD9CF;
  cursor: pointer;
  position: relative;
.cl-gallery__item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 400ms ease;
.cl-gallery__item:hover img {
  transform: scale(1.02);
.cl-gallery__item--landscape { aspect-ratio: 4 / 3; }
.cl-gallery__item--portrait  { aspect-ratio: 3 / 4; }
.cl-gallery__item--wide      { aspect-ratio: 16 / 9; }
.cl-gallery__item--square    { aspect-ratio: 1 / 1; }
.cl-gallery__item--tall      { aspect-ratio: 2 / 3; }
.cl-gallery__placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  min-height: 200px;
  background: #DDD9CF;
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 10px;
  font-weight: 400;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #9A9588;
.cl-lightbox {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 999999;
  background: rgba(44, 40, 48, 0.94);
  align-items: center;
  justify-content: center;
  padding: 40px;
  box-sizing: border-box;
.cl-lightbox.is-open {
  display: flex;
.cl-lightbox__img {
  max-width: 90vw;
  max-height: 88vh;
  object-fit: contain;
  display: block;
  box-shadow: 0 8px 48px rgba(0,0,0,0.5);
.cl-lightbox__close {
  position: fixed;
  top: 24px;
  right: 32px;
  background: none;
  border: none;
  color: rgba(250,248,245,0.7);
  font-size: 28px;
  cursor: pointer;
  line-height: 1;
  transition: color 200ms ease;
  z-index: 1000001;
  font-family: 'Inter', system-ui, sans-serif;
  font-weight: 300;
.cl-lightbox__close:hover { color: #FAF8F5; }
.cl-lightbox__prev,
.cl-lightbox__next {
  position: fixed;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  color: rgba(250,248,245,0.6);
  font-size: 32px;
  cursor: pointer;
  padding: 16px;
  transition: color 200ms ease;
  z-index: 1000001;
  font-family: 'Inter', system-ui, sans-serif;
  font-weight: 300;
  line-height: 1;
.cl-lightbox__prev { left: 16px; }
.cl-lightbox__next { right: 16px; }
.cl-lightbox__prev:hover,
.cl-lightbox__next:hover { color: #FAF8F5; }
/* ============================================================
   PROPERTY PAGE 
 SECTION 3: BODY COPY
   ============================================================ */
.cl-property-body-section {
  padding: 64px 0 72px 0 !important;
  background-color: #FAF8F5 !important;
.cl-property-body-section .cl-portfolio {
  padding-left: 80px !important;
  padding-right: 80px !important;
.cl-property-body-section .elementor-widget-wrap,
.cl-property-body-section .elementor-column-wrap > .elementor-widget-wrap {
  padding: 0 !important;
.cl-property-body {
  max-width: 780px;
  margin-bottom: 48px;
.cl-property-body p {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 15px !important;
  font-weight: 300 !important;
  line-height: 1.85 !important;
  color: #4A4840 !important;
  margin: 0 !important;
  padding-bottom: 18px !important;
.cl-designer-btn {
  display: inline-block !important;
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 11px !important;
  font-weight: 400 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  color: #6B2D68 !important;
  text-decoration: none !important;
  border-bottom: 0.5px solid #6B2D68 !important;
  padding-bottom: 2px !important;
  margin-bottom: 20px !important;
  background: none !important;
  transition: color 200ms ease, border-color 200ms ease !important;
.cl-designer-btn:hover {
  color: #38203A !important;
  border-color: #38203A !important;
/* ============================================================
   PROPERTY PAGE 
 SECTION 4: TESTIMONIAL
   ============================================================ */
.cl-property-testimonial-section {
  padding: 40px 0 8px 0 !important;
  background-color: #FAF8F5 !important;
.cl-property-testimonial-section .cl-portfolio {
  padding-left: 80px !important;
  padding-right: 80px !important;
.cl-property-testimonial-section .elementor-widget-wrap,
.cl-property-testimonial-section .elementor-column-wrap > .elementor-widget-wrap {
  padding: 0 !important;
.cl-testimonial {
  max-width: 620px;
  padding: 32px 40px;
  border-left: 2px solid #C4A8C2;
  background: #FAF8F5;
.cl-testimonial__quote {
  font-family: 'Fraunces', Georgia, serif !important;
  font-size: 20px !important;
  font-weight: 300 !important;
  font-style: italic !important;
  line-height: 1.65 !important;
  color: #2C2830 !important;
  margin: 0 0 20px 0 !important;
.cl-testimonial__attr {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 11px !important;
  font-weight: 400 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  color: #9A9588 !important;
  margin: 0 !important;
/* ============================================================
   PROPERTY PAGE + HUB PAGE 
 SECTION 5: SEARCH
   ============================================================ */
.cl-search-section {
  padding: 32px 0 0 0 !important;
  background-color: #FAF8F5 !important;
.cl-search {
  max-width: 100%;
  border-top: 0.5px solid #DDD9D2;
  padding-top: 28px;
  padding-bottom: 32px;
  padding-left: 80px;
  padding-right: 80px;
.cl-search__bar {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 16px;
.cl-search__input {
  flex: 1;
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 13px !important;
  font-weight: 300 !important;
  color: #2C2830 !important;
  background: transparent !important;
  border: none !important;
  border-bottom: 0.5px solid #DDD9D2 !important;
  border-radius: 0 !important;
  padding: 8px 0 !important;
  outline: none !important;
  letter-spacing: 0.02em;
  max-width: 480px;
.cl-search__input:focus {
  border-bottom-color: #6B2D68 !important;
.cl-search__input::placeholder {
  color: #9A9588;
  font-weight: 300;
.cl-search__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
.cl-search__tag {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 10px;
  font-weight: 400;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #9A9588;
  border: 0.5px solid #DDD9D2;
  padding: 5px 12px;
  cursor: pointer;
  background: none;
  transition: color 200ms ease, border-color 200ms ease, background 200ms ease;
.cl-search__tag:hover,
.cl-search__tag.is-active {
  color: #6B2D68;
  border-color: #6B2D68;
  background: rgba(107, 45, 104, 0.04);
.cl-search__clear {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 10px;
  font-weight: 300;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #9A9588;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  display: none;
  transition: color 200ms ease;
.cl-search__clear.is-visible { display: inline; }
.cl-search__clear:hover { color: #6B2D68; }
.cl-search__count {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 11px;
  font-weight: 300;
  color: #9A9588;
  letter-spacing: 0.04em;
  margin-top: 8px;
/* ============================================================
   PROPERTY CAROUSEL 
 hub page
   ============================================================ */
.cl-carousel-section {
  padding: 0 !important;
  overflow: hidden !important;
  background-color: #FAF8F5 !important;
  border-top: 0.5px solid #DDD9D2;
.cl-carousel {
  position: relative;
  overflow: hidden;
  width: 100%;
.cl-carousel__track {
  display: flex;
  will-change: transform;
.cl-carousel__slide {
  min-width: 100%;
  position: relative;
  cursor: pointer;
  display: block;
  text-decoration: none;
.cl-carousel__img-wrap {
  width: 100%;
  aspect-ratio: 16 / 7;
  overflow: hidden;
  background: #DDD9CF;
  position: relative;
.cl-carousel__img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
.cl-carousel__placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #DDD9CF;
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #9A9588;
.cl-carousel__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(44,40,48,0.72) 0%, rgba(44,40,48,0.1) 55%, transparent 100%);
  pointer-events: none;
.cl-carousel__caption {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 40px 80px 48px 80px;
  box-sizing: border-box;
.cl-carousel__eyebrow {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 10px;
  font-weight: 400;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(250,248,245,0.65);
  display: block;
  margin-bottom: 10px;
.cl-carousel__title {
  font-family: 'Fraunces', Georgia, serif;
  font-size: 36px;
  font-weight: 300;
  color: #FAF8F5;
  line-height: 1.15;
  margin: 0;
  max-width: 680px;
.cl-carousel__controls {
  display: flex;
  align-items: center;
  gap: 0;
  border-top: 0.5px solid #DDD9D2;
.cl-carousel__btn {
  background: none;
  border: none;
  border-right: 0.5px solid #DDD9D2;
  padding: 18px 28px;
  cursor: pointer;
  color: #9A9588;
  font-size: 18px;
  line-height: 1;
  transition: color 200ms ease, background 200ms ease;
  font-family: 'Inter', system-ui, sans-serif;
.cl-carousel__btn:last-child { border-right: none; }
.cl-carousel__btn:hover { color: #6B2D68; background: rgba(107,45,104,0.04); }
.cl-carousel__dots {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 28px;
  flex: 1;
.cl-carousel__dot {
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: #DDD9D2;
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background 200ms ease;
.cl-carousel__dot.is-active { background: #6B2D68; }
.cl-carousel__counter {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 11px;
  font-weight: 300;
  color: #9A9588;
  letter-spacing: 0.06em;
  padding: 0 28px 0 0;
/* ============================================================
   DESIGNER BIO PAGE
   ============================================================ */
.cl-designer-bio.e-con {
  padding-top: 108px !important;
.cl-bio {
  display: grid;
  grid-template-columns: 1fr 1fr;
  width: 100%;
  min-height: calc(100vh - 80px);
  background: #FAF8F5 !important;
.cl-bio__left {
  background: #FAF8F5;
  border-right: 0.5px solid #DDD9D2;
  padding: 80px 56px 72px 80px;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  box-sizing: border-box;
.cl-bio__eyebrow {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 11px;
  font-weight: 400;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #9A9588;
  display: block;
  margin: 0 0 20px 0;
.cl-bio__name {
  font-family: 'Fraunces', Georgia, serif !important;
  font-size: 52px !important;
  font-weight: 300 !important;
  line-height: 1.1 !important;
  color: #2C2830 !important;
  margin: 0 0 36px 0 !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
.cl-bio__body {
  max-width: 480px;
  margin-bottom: 40px;
.cl-bio__body p {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 15px !important;
  font-weight: 300 !important;
  line-height: 1.85 !important;
  color: #4A4840 !important;
  margin: 0 0 18px 0 !important;
.cl-bio__quote {
  font-family: 'Fraunces', Georgia, serif;
  font-size: 22px;
  font-weight: 300;
  font-style: italic;
  line-height: 1.5;
  color: #6B2D68;
  margin: 0 0 40px 0;
  padding: 0;
  border: none;
  max-width: 440px;
.cl-bio__quote::before { content: '\201C'; }
.cl-bio__quote::after  { content: '\201D'; }
.cl-bio__signature {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 48px;
.cl-bio__signature-rule {
  width: 32px;
  height: 0.5px;
  background: #C4A8C2;
  flex-shrink: 0;
  display: block;
.cl-bio__signature-name {
  font-family: 'Fraunces', Georgia, serif;
  font-size: 22px;
  font-weight: 300;
  font-style: italic;
  color: #6B2D68;
.cl-bio__projects {
  border-top: 0.5px solid #DDD9D2;
  padding-top: 32px;
  margin-bottom: 8px;
.cl-bio__projects-label {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 11px !important;
  font-weight: 400 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  color: #9A9588 !important;
  margin: 0 0 20px 0 !important;
.cl-bio__project-link {
  display: flex;
  align-items: baseline;
  gap: 12px;
  text-decoration: none;
  padding: 14px 0;
  border-bottom: 0.5px solid #DDD9D2;
  transition: background 200ms ease;
.cl-bio__project-link:first-of-type {
  border-top: 0.5px solid #DDD9D2;
.cl-bio__project-link:hover .cl-bio__project-title {
  color: #6B2D68 !important;
.cl-bio__project-title {
  font-family: 'Fraunces', Georgia, serif !important;
  font-size: 18px !important;
  font-weight: 300 !important;
  color: #2C2830 !important;
  flex: 1;
  transition: color 200ms ease;
.cl-bio__project-tags {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 11px !important;
  font-weight: 300 !important;
  color: #9A9588 !important;
  letter-spacing: 0.04em !important;
.cl-bio__project-arrow {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 14px;
  color: #9A9588;
  transition: color 200ms ease;
.cl-bio__project-link:hover .cl-bio__project-arrow {
  color: #6B2D68;
.cl-bio__right {
  background: #DDD9CF;
  position: relative;
  display: block;
  min-height: 600px;
  overflow: hidden;
.cl-bio__portrait-wrap {
  position: absolute;
  inset: 0;
  bottom: 96px;
  padding: 0;
  overflow: hidden;
  border-radius: 6px;
.cl-bio__portrait-placeholder {
  width: 100%;
  height: 100%;
  min-height: 400px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #DDD9CF;
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #9A9588;
.cl-bio__portrait-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
.cl-bio__caption {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  background: #FAF8F5;
  padding: 20px 40px;
  box-sizing: border-box;
  border-top: 0.5px solid #DDD9D2;
.cl-bio__caption-name {
  font-family: 'Fraunces', Georgia, serif;
  font-size: 18px;
  font-weight: 400;
  color: #2C2830;
  display: block;
  margin: 0;
.cl-bio__caption-title {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 11px;
  font-weight: 400;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #9A9588;
  display: block;
  margin: 4px 0 0 0;
/* ============================================================
   DESIGN HUB PAGE 
 /design/
   Session 7 
 15 April 2026
   ============================================================ */
/* Shared utility classes scoped to Design Hub widgets */
.cl-dh-eyebrow {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 11px !important;
  font-weight: 400 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  color: #9A9588 !important;
  display: block;
  margin-bottom: 20px !important;
.cl-dh-h2 {
  font-family: 'Fraunces', Georgia, serif !important;
  font-size: clamp(28px, 3vw, 42px) !important;
  font-weight: 300 !important;
  line-height: 1.15 !important;
  color: #2C2830 !important;
  letter-spacing: -0.01em !important;
  margin: 0 !important;
.cl-dh-h2 em {
  font-style: italic !important;
  color: #6B2D68 !important;
.cl-dh-link {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 11px !important;
  font-weight: 400 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  color: #2C2830 !important;
  text-decoration: none;
  border-bottom: 0.5px solid #6B2D68;
  padding-bottom: 2px;
  display: inline-flex;
  align-items: center;
  gap: 7px;
.cl-dh-link:hover {
  color: #6B2D68 !important;
/* Hero */
.cl-dh-hero {
  position: relative;
  width: 100%;
  height: 88vh;
  min-height: 540px;
  max-height: 820px;
  overflow: hidden;
  background: #38203A;
.cl-dh-hero-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 40%;
.cl-dh-hero-veil {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(
      to right,
      rgba(44,40,48,0.72) 0%,
      rgba(44,40,48,0.48) 35%,
      rgba(44,40,48,0.10) 65%,
      rgba(44,40,48,0.00) 100%
    ),
    linear-gradient(
      to top,
      rgba(44,40,48,0.62) 0%,
      rgba(44,40,48,0.10) 45%,
      rgba(44,40,48,0.00) 100%
    );
.cl-dh-hero-content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 0 48px 72px;
  max-width: 1256px;
  margin: 0 auto;
.cl-dh-hero-eyebrow {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 11px !important;
  font-weight: 300 !important;
  letter-spacing: 0.2em !important;
  text-transform: uppercase !important;
  color: rgba(250,248,245,0.55) !important;
  margin-bottom: 18px !important;
  display: block;
.cl-dh-hero-h1 {
  font-family: 'Fraunces', Georgia, serif !important;
  font-size: clamp(36px, 5.5vw, 72px) !important;
  font-weight: 300 !important;
  line-height: 1.08 !important;
  color: #FAF8F5 !important;
  letter-spacing: -0.015em !important;
  margin: 0 0 4px !important;
  max-width: 720px;
.cl-dh-hero-h1 em {
  font-style: italic !important;
  color: #C4A8C2 !important;
.cl-dh-hero-sub {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 15px !important;
  font-weight: 300 !important;
  line-height: 1.7 !important;
  color: rgba(250,248,245,0.72) !important;
  max-width: 460px;
  margin-top: 20px !important;
/* Geography strip */
.cl-dh-geo {
  background: #2C2830;
  padding: 48px 0;
.cl-dh-geo-inner {
  max-width: 1160px;
  margin: 0 auto;
  padding: 0 48px;
  display: grid;
  grid-template-columns: 1fr 0.5px 1fr;
  gap: 0 56px;
  align-items: center;
.cl-dh-geo-rule {
  background: rgba(221,217,210,0.18);
  height: 48px;
  align-self: center;
.cl-dh-geo-item {
  display: flex;
  align-items: flex-start;
  gap: 18px;
.cl-dh-geo-icon {
  flex-shrink: 0;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: 0.5px solid rgba(221,217,210,0.3);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 3px;
.cl-dh-geo-label {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 10px !important;
  font-weight: 400 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  color: rgba(250,248,245,0.38) !important;
  margin-bottom: 5px !important;
  display: block;
.cl-dh-geo-place {
  font-family: 'Fraunces', Georgia, serif !important;
  font-size: 18px !important;
  font-weight: 300 !important;
  color: #FAF8F5 !important;
  line-height: 1.25 !important;
  margin-bottom: 5px !important;
  display: block;
.cl-dh-geo-desc {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 13px !important;
  font-weight: 300 !important;
  color: rgba(250,248,245,0.48) !important;
  line-height: 1.6 !important;
/* Rain Gardens */
.cl-dh-rain {
  background: #FAF8F5;
  padding: 108px 0;
  border-top: 0.5px solid #DDD9D2;
.cl-dh-rain-inner {
  max-width: 1160px;
  margin: 0 auto;
  padding: 0 48px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 96px;
  align-items: center;
.cl-dh-rain-h2 {
  font-family: 'Fraunces', Georgia, serif !important;
  font-size: clamp(26px, 2.8vw, 40px) !important;
  font-weight: 300 !important;
  line-height: 1.18 !important;
  color: #2C2830 !important;
  margin: 0 0 28px !important;
  letter-spacing: -0.01em !important;
.cl-dh-rain-h2 em {
  font-style: italic !important;
  color: #6B2D68 !important;
.cl-dh-rain-body {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 15px !important;
  font-weight: 300 !important;
  line-height: 1.85 !important;
  color: #4A4840 !important;
  margin-bottom: 36px !important;
  max-width: 420px;
.cl-dh-rain-stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: #DDD9D2;
.cl-dh-rain-stat {
  background: #FAF8F5;
  padding: 52px 36px 44px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
.cl-dh-rain-stat-icon {
  margin-bottom: 24px;
.cl-dh-rain-stat-num {
  font-family: 'Fraunces', Georgia, serif !important;
  font-size: clamp(42px, 5vw, 62px) !important;
  font-weight: 300 !important;
  color: #2C2830 !important;
  line-height: 1 !important;
  letter-spacing: -0.02em !important;
  margin-bottom: 16px !important;
.cl-dh-rain-stat-rule {
  width: 24px;
  height: 0.5px;
  background: #C4A8C2;
  margin-bottom: 12px;
.cl-dh-rain-stat-label {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 10px !important;
  font-weight: 400 !important;
  letter-spacing: 0.15em !important;
  text-transform: uppercase !important;
  color: #9A9588 !important;
  line-height: 1.5 !important;
/* What We Design */
.cl-dh-what {
  background: #FAF8F5;
  padding: 108px 0;
  border-top: 0.5px solid #DDD9D2;
.cl-dh-what-inner {
  max-width: 1160px;
  margin: 0 auto;
  padding: 0 48px;
  display: grid;
  grid-template-columns: 320px 1fr;
  gap: 96px;
  align-items: start;
.cl-dh-what-body p {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 15px !important;
  font-weight: 300 !important;
  line-height: 1.85 !important;
  color: #4A4840 !important;
  margin-bottom: 18px !important;
  max-width: 520px;
.cl-dh-what-body p:last-child {
  margin-bottom: 0 !important;
/* Selected Work */
.cl-dh-work2 {
  background: #DDD9CF;
  padding: 108px 0;
.cl-dh-work2-inner {
  max-width: 1160px;
  margin: 0 auto;
  padding: 0 48px;
.cl-dh-work2-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: 48px;
.cl-dh-work2-card {
  display: grid;
  grid-template-columns: 3fr 2fr;
  gap: 16px;                        /* gap between video and right column */
  background: #DDD9D2;              /* linen shows through gap as fine line */
  border-radius: 6px;
  overflow: hidden;
  height: 680px;                    /* fixed height 
 both columns bounded equally */
/* Left column 
 video */
.cl-dh-work2-video-wrap {
  overflow: hidden;
  background: #2C2830;
  position: relative;
  border-radius: 6px;
  height: 100%;                     /* fills card height exactly */
.cl-dh-work2-video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
  transition: transform 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
.cl-dh-work2-card:hover .cl-dh-work2-video {
  transform: scale(1.03);
/* Right column 
 split into two stacked panels */
.cl-dh-work2-right {
  display: grid;
  grid-template-rows: 1fr 1fr;
  gap: 16px;                        /* gap between text panel and image */
  background: transparent;
  height: 100%;                     /* fills card height exactly */
/* Top right 
 text */
.cl-dh-work2-text {
  background: #FAF8F5;
  padding: 52px 48px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  border-radius: 6px;               /* rounds text panel corners */
.cl-dh-work2-tags {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 10px !important;
  font-weight: 400 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  color: #9A9588 !important;
  display: block;
  margin-bottom: 14px !important;
.cl-dh-work2-title {
  font-family: 'Fraunces', Georgia, serif !important;
  font-size: clamp(22px, 2.5vw, 34px) !important;
  font-weight: 300 !important;
  line-height: 1.2 !important;
  color: #2C2830 !important;
  margin: 0 0 24px 0 !important;
.cl-dh-work2-desc {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 14px !important;
  font-weight: 300 !important;
  line-height: 1.75 !important;
  color: #4A4840 !important;
  margin: 0 !important;
  max-width: 320px;
.cl-dh-work2-rule {
  width: 100%;
  height: 0.5px;
  background: #DDD9D2;
  margin: 32px 0 24px;
.cl-dh-work2-cta {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 11px !important;
  font-weight: 400 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  color: #9A9588 !important;
  border-bottom: 0.5px solid #6B2D68;
  padding-bottom: 2px;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  transition: color 200ms ease;
.cl-dh-work2-card:hover .cl-dh-work2-cta {
  color: #6B2D68 !important;
/* Bottom right 
 static image */
.cl-dh-work2-img-wrap {
  overflow: hidden;
  display: block;
  position: relative;
  border-radius: 6px;               /* rounds image corners */
.cl-dh-work2-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  display: block;
  transition: transform 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
.cl-dh-work2-img-wrap:hover .cl-dh-work2-img {
  transform: scale(1.04);
/* Our Process */
.cl-dh-process {
  background: #FAF8F5;
  padding: 108px 0;
  border-top: 0.5px solid #DDD9D2;
.cl-dh-process-inner {
  max-width: 1160px;
  margin: 0 auto;
  padding: 0 48px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 96px;
  align-items: start;
.cl-dh-process-body {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 15px !important;
  font-weight: 300 !important;
  line-height: 1.85 !important;
  color: #4A4840 !important;
  margin: 28px 0 36px !important;
  max-width: 420px;
.cl-dh-process-steps {
  padding-top: 4px;
.cl-dh-process-step {
  display: flex;
  gap: 24px;
  padding: 26px 0;
  border-bottom: 0.5px solid #DDD9D2;
  align-items: flex-start;
.cl-dh-process-step:first-child {
  border-top: 0.5px solid #DDD9D2;
.cl-dh-process-num {
  font-family: 'Fraunces', Georgia, serif !important;
  font-size: 13px !important;
  font-weight: 300 !important;
  color: #9A9588 !important;
  flex-shrink: 0;
  min-width: 22px;
  margin-top: 1px;
.cl-dh-process-step-name {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 14px !important;
  font-weight: 400 !important;
  color: #2C2830 !important;
  margin-bottom: 4px !important;
.cl-dh-process-step-desc {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 13px !important;
  font-weight: 300 !important;
  color: #9A9588 !important;
  line-height: 1.65 !important;
/* Credentials */
.cl-dh-creds {
  background: #DDD9CF;
  padding: 108px 0;
.cl-dh-creds-inner {
  max-width: 1160px;
  margin: 0 auto;
  padding: 0 48px;
.cl-dh-creds-header {
  margin-bottom: 56px;
  max-width: 520px;
.cl-dh-creds-header .cl-dh-h2 {
  margin-top: 20px !important;
.cl-dh-creds-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: #DDD9D2;
.cl-dh-cred-item {
  background: #FAF8F5;
  padding: 40px 28px;
.cl-dh-cred-org {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 10px !important;
  font-weight: 400 !important;
  letter-spacing: 0.16em !important;
  text-transform: uppercase !important;
  color: #9A9588 !important;
  display: block;
  margin-bottom: 10px !important;
.cl-dh-cred-name {
  font-family: 'Fraunces', Georgia, serif !important;
  font-size: 16px !important;
  font-weight: 300 !important;
  line-height: 1.4 !important;
  color: #2C2830 !important;
.cl-dh-cred-logo-wrap {
  height: 56px;
  display: flex;
  align-items: center;
  margin-bottom: 20px;
.cl-dh-cred-logo {
  max-height: 48px;
  width: auto;
  display: block;
  filter: saturate(0.4) opacity(0.75);
  transition: filter 300ms ease;
.cl-dh-cred-item:hover .cl-dh-cred-logo {
  filter: saturate(1) opacity(1);
.cl-dh-cred-divider {
  width: 100%;
  height: 0.5px;
  background: #DDD9D2;
  margin-bottom: 16px;
/* Resources */
.cl-dh-resources {
  background: #FAF8F5;
  padding: 108px 0;
  border-top: 0.5px solid #DDD9D2;
.cl-dh-resources-inner {
  max-width: 1160px;
  margin: 0 auto;
  padding: 0 48px;
.cl-dh-resources-header {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 96px;
  margin-bottom: 56px;
  align-items: end;
.cl-dh-resources-intro {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 15px !important;
  font-weight: 300 !important;
  line-height: 1.85 !important;
  color: #4A4840 !important;
  padding-bottom: 6px;
.cl-dh-resources-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: #DDD9D2;
.cl-dh-resource-card {
  background: #FAF8F5;
  padding: 36px 28px 32px;
  display: flex;
  flex-direction: column;
  text-decoration: none;
  transition: background 200ms ease;
.cl-dh-resource-card:hover {
  background: #F0EDE8;
.cl-dh-resource-cat {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 10px !important;
  font-weight: 400 !important;
  letter-spacing: 0.16em !important;
  text-transform: uppercase !important;
  color: #9A9588 !important;
  display: block;
  margin-bottom: 10px !important;
.cl-dh-resource-title {
  font-family: 'Fraunces', Georgia, serif !important;
  font-size: 17px !important;
  font-weight: 300 !important;
  line-height: 1.4 !important;
  color: #2C2830 !important;
  flex-grow: 1;
  margin-bottom: 20px !important;
.cl-dh-resource-read {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 11px !important;
  font-weight: 400 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  color: #9A9588 !important;
  border-bottom: 0.5px solid #DDD9D2;
  padding-bottom: 2px;
  display: inline-block;
  align-self: flex-start;
  transition: color 200ms ease, border-color 200ms ease;
.cl-dh-resource-card:hover .cl-dh-resource-read {
  color: #6B2D68 !important;
  border-bottom-color: #6B2D68;
/* ============================================================
   RESPONSIVE 
 ALL PAGES
   ============================================================ */
@media (max-width: 900px) {
  /* Contact */
  .cl-nav { padding: 0 24px; height: 60px; }
  .cl-nav-links { gap: 20px; }
  .cl-nav-links a { font-size: 11px; }
  .cl-body { grid-template-columns: 1fr; }
  .cl-left { padding: 48px 32px; border-right: none; border-bottom: 0.5px solid var(--cl-border); }
  .cl-headline { font-size: 38px !important; }
  .cl-right { min-height: 480px; }
  .cl-footer { grid-template-columns: repeat(2, 1fr); }
  .cl-footer-cell:nth-child(2) { border-right: none; }
  .cl-footer-cell:nth-child(3) { border-top: 0.5px solid var(--cl-border); }
  .cl-footer-cell:nth-child(4) { border-top: 0.5px solid var(--cl-border); border-right: none; }
  /* Homepage */
  .cl-services { padding: 60px 32px 72px 32px; }
  .cl-services-grid { grid-template-columns: 1fr; gap: 40px; }
  .cl-services-title { font-size: 36px !important; }
  .cl-cta { padding: 72px 32px; }
  .cl-cta-title { font-size: 40px !important; }
  .cl-work-section { padding: 64px 40px 80px 40px; }
  .cl-work-title { font-size: 36px !important; }
  .cl-work-divider { max-width: 100%; }
  .cl-featured-image { height: 400px !important; }
  .cl-philosophy-section { padding: 64px 40px 80px 40px; }
  .cl-philosophy-inner { gap: 40px; }
  .cl-philosophy-title { font-size: 36px !important; }
  .cl-philosophy-image img { height: 420px !important; }
  /* Hero */
  .cl-hero .cl-hero-content .cl-hero-h1 { font-size: 48px !important; }
  .cl-hero-content { padding: 140px 0 60px 40px !important; }
  .cl-hero .cl-hero-content .cl-hero-sub { font-size: 16px !important; }
  /* Positioning */
  .cl-positioning-section { padding: 64px 40px; }
  .cl-positioning-inner { gap: 40px; }
  .cl-positioning-h2 { font-size: 30px !important; }
  .cl-positioning-body { font-size: 16px !important; }
  /* Portfolio hub */
  .cl-portfolio-intro-section .cl-portfolio,
  .cl-portfolio-grid-section .cl-portfolio { padding-left: 40px !important; padding-right: 40px !important; }
  .cl-portfolio h1,
  .cl-portfolio h1.cl-headline,
  .cl-portfolio .cl-headline { font-size: 38px !important; }
  /* Carousel */
  .cl-carousel__caption { padding: 32px 40px 40px 40px; }
  .cl-carousel__title { font-size: 28px; }
  /* Search */
  .cl-search { padding-left: 40px; padding-right: 40px; }
  /* Property pages */
  .cl-property-hero-section { padding: 60px 0 24px 0 !important; }
  .cl-property-hero-section .cl-portfolio,
  .cl-property-body-section .cl-portfolio,
  .cl-property-testimonial-section .cl-portfolio { padding-left: 40px !important; padding-right: 40px !important; }
  .cl-gallery { padding-left: 40px !important; padding-right: 40px !important; }
  .cl-gallery--hero-plus-four { display: flex; flex-direction: column; height: auto; }
  .cl-gallery--hero-plus-four .cl-gallery__item { aspect-ratio: 4 / 3; width: 100%; }
  .cl-gallery--hero-plus-two { grid-template-columns: 1fr; width: 100%; }
  .cl-gallery--hero-plus-two .cl-gallery__item:first-child { grid-row: span 1; }
  .cl-gallery--three-up { grid-template-columns: 1fr 1fr; }
  /* Bio page */
  .cl-bio { grid-template-columns: 1fr; }
  .cl-bio__left { padding: 48px 40px; border-right: none; border-bottom: 0.5px solid #DDD9D2; }
  .cl-bio__right { min-height: 480px; }
  /* Portfolio hub footer */
  .cl-portfolio-footer { grid-template-columns: 1fr 1fr !important; }
  .cl-portfolio-footer__cell:nth-child(2) { border-right: none !important; }
  .cl-portfolio-footer__cell:nth-child(3) { border-top: 0.5px solid #DDD9D2 !important; border-right: none !important; }
  /* Design Hub */
  .cl-dh-hero { height: 75vh; min-height: 440px; }
  .cl-dh-hero-content { padding-bottom: 48px; }
  .cl-dh-geo-inner { grid-template-columns: 1fr; gap: 36px 0; }
  .cl-dh-geo-rule { display: none; }
  .cl-dh-rain-inner { grid-template-columns: 1fr; gap: 0; }
  .cl-dh-rain-stats { order: -1; margin-bottom: 56px; }
  .cl-dh-what-inner { grid-template-columns: 1fr; gap: 40px; }
  .cl-dh-work2-header { flex-direction: column; align-items: flex-start; gap: 16px; }
  .cl-dh-work2-card { grid-template-columns: 1fr; gap: 16px; height: auto; }
  .cl-dh-work2-video-wrap { aspect-ratio: 4/3; height: auto; }
  .cl-dh-work2-right { grid-template-rows: auto auto; gap: 16px; height: auto; }
  .cl-dh-work2-img-wrap { aspect-ratio: 4/3; }
  .cl-dh-process-inner { grid-template-columns: 1fr; gap: 48px; }
  .cl-dh-creds-grid { grid-template-columns: repeat(2, 1fr); }
  .cl-dh-resources-header { grid-template-columns: 1fr; gap: 24px; }
  .cl-dh-resources-grid { grid-template-columns: repeat(2, 1fr); }
@media (max-width: 600px) {
  /* Contact */
  .cl-nav-links { display: none; }
  .cl-headline { font-size: 32px !important; }
  .cl-footer { grid-template-columns: 1fr; }
  .cl-footer-cell { border-right: none; border-top: 0.5px solid var(--cl-border); padding: 20px 32px; }
  .cl-footer-cell:first-child { border-top: none; }
  .cl-modal-box { padding: 36px 28px 40px !important; }
  /* Homepage */
  .cl-cta { padding: 56px 24px; }
  .cl-cta-title { font-size: 32px !important; }
  .cl-hero .cl-hero-content .cl-hero-h1 { font-size: 36px !important; }
  .cl-hero-content { padding: 100px 0 48px 24px !important; }
  .cl-hero .cl-hero-content .cl-hero-sub { font-size: 15px !important; }
  .cl-work-section { padding: 48px 24px 64px 24px; }
  .cl-work-title { font-size: 30px !important; }
  .cl-work-divider { max-width: 100%; }
  .cl-featured-image { height: 300px !important; }
  .cl-secondary-projects { flex-direction: column; gap: 32px; }
  .cl-project-name { font-size: 20px !important; }
  .cl-philosophy-section { padding: 48px 24px 64px 24px; }
  .cl-philosophy-inner { grid-template-columns: 1fr; gap: 32px; }
  .cl-philosophy-title { font-size: 28px !important; }
  .cl-philosophy-image img { height: 280px !important; }
  .cl-services { padding: 48px 24px 56px 24px; }
  .cl-services-title { font-size: 28px !important; }
  .cl-services-intro { font-size: 15px !important; }
  /* Portfolio hub */
  .cl-portfolio .cl-cards { grid-template-columns: 1fr !important; }
  .cl-portfolio-intro-section .cl-portfolio,
  .cl-portfolio-grid-section .cl-portfolio { padding-left: 24px !important; padding-right: 24px !important; }
  .cl-portfolio h1,
  .cl-portfolio h1.cl-headline,
  .cl-portfolio .cl-headline { font-size: 32px !important; }
  .cl-portfolio-footer { grid-template-columns: 1fr !important; }
  .cl-portfolio-footer__cell { border-right: none !important; border-bottom: 0.5px solid #DDD9D2 !important; padding: 24px 32px !important; }
  .cl-portfolio-footer__cell:last-child { border-bottom: none !important; }
  /* Carousel */
  .cl-carousel__caption { padding: 24px 24px 32px 24px; }
  .cl-carousel__title { font-size: 22px; }
  /* Search */
  .cl-search { padding-left: 24px; padding-right: 24px; }
  /* Property pages */
  .cl-property-hero-section { padding: 40px 0 20px 0 !important; }
  .cl-property-hero-section .cl-portfolio,
  .cl-property-body-section .cl-portfolio,
  .cl-property-testimonial-section .cl-portfolio { padding-left: 24px !important; padding-right: 24px !important; }
  .cl-gallery { padding-left: 24px !important; padding-right: 24px !important; }
  .cl-gallery--hero-plus-four { display: flex; flex-direction: column; height: auto; }
  .cl-gallery--hero-plus-four .cl-gallery__item { aspect-ratio: 4 / 3; width: 100%; }
  .cl-gallery--two-up,
  .cl-gallery--three-up,
  .cl-gallery--two-portrait { grid-template-columns: 1fr; }
  .cl-gallery--hero-plus-two { grid-template-columns: 1fr; width: 100%; }
  .cl-gallery__item:first-child { grid-row: span 1; }
  .cl-property-body-section { padding: 48px 0 60px 0 !important; }
  /* Bio page */
  .cl-bio__left { padding: 40px 24px; }
  .cl-bio__name { font-size: 38px !important; }
  /* Positioning */
  .cl-positioning-section { padding: 48px 24px; }
  .cl-positioning-inner { grid-template-columns: 1fr; gap: 32px; }
  .cl-positioning-h2 { font-size: 26px !important; }
  .cl-positioning-body { font-size: 15px !important; }
  /* Design Hub */
  .cl-dh-rain { padding: 72px 0; }
  .cl-dh-rain-stats { grid-template-columns: 1fr; }
  .cl-dh-what { padding: 72px 0; }
  .cl-dh-work2 { padding: 72px 0; }
  .cl-dh-work2-text { padding: 36px 28px; }
  .cl-dh-process { padding: 72px 0; }
  .cl-dh-creds { padding: 72px 0; }
  .cl-dh-creds-grid { grid-template-columns: 1fr; }
  .cl-dh-resources { padding: 72px 0; }
  .cl-dh-resources-grid { grid-template-columns: 1fr; }
