/* ============================================================
   TERRIFIC — Global Stylesheet
   Upload to: Design Manager > Stylesheets > terrific-global.css
   Attach to: All site pages (Settings > Website > Pages)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Instrument+Serif:ital@0;1&display=swap');
@import url('https://api.fontshare.com/v2/css?f[]=general-sans@400,500,300&display=swap');
@import url('https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;600;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300&display=swap');

:root {

  /* --- Colour palette --- */
  --t-coral:          #D94F3A;
  --t-coral-hover:    #C0402C;
  --t-coral-light:    #F5E8E5;
  --t-magenta: #E92B6D;
  --t-magenta-light: #FBE4ED;

  --t-cream:          #FAF7F4;
  --t-cream-light:    #F4F1EE;
  --t-cream-dark:     #F2EDE6;
  --t-white:          #FFFFFF;

  --t-dark:           #1C1B19;
  --t-dark-secondary: #2A2926;

  --t-hero-from:      #F5C4B0;
  --t-hero-to:        #FAF7F4;

  --t-text-primary:   #1C1B19;
  --t-text-muted:     #6B6860;
  --t-text-light:     #9E9B95;
  --t-text-dark:      #3A3A3A;
  --t-text-on-dark:   #F5F2EE;
  --t-text-muted-dark:#9E9B95;

  --t-border:         #E8E3DC;
  --t-border-strong:  #C9C3BB;   /* stronger dividers */


  --t-font-serif: 'Instrument Serif', Georgia, serif;
  --t-font-sans:  'General Sans', system-ui, -apple-system, sans-serif;
  --t-font-jetbrains: 'JetBrains Mono', system-ui, -apple-system, sans-serif;
  --t-font-nunito: 'Outfit', system-ui, -apple-system, sans-serif;

  --t-text-xs:        0.75rem;    /*  12px */
  --t-text-sm:        0.875rem;   /*  14px */
  --t-text-base:      1rem;       /*  16px */
  --t-text-lg:        1.125rem;   /*  18px */
  --t-text-xl:        1.375rem;   /*  22px */
  --t-text-2xl:       1.75rem;    /*  28px */
  --t-text-3xl:       2.25rem;    /*  36px */
  --t-text-4xl:       3rem;       /*  48px */
  --t-text-5xl:       3.75rem;    /*  60px */
  --t-text-hero:      4.5rem;     /*  72px — hero headline */

  
  --t-leading-tight:  1.15;
  --t-leading-snug:   1.3;
  --t-leading-normal: 1.6;
  --t-leading-relaxed:1.75;


  --t-section-pad-y:  80px;
  --t-section-pad-y-sm: 56px;
  --t-container-max:  1460px;
  --t-container-pad:  40px;


  --t-radius-sm:      4px;
  --t-radius-md:      8px;
  --t-radius-lg:      12px;
  --t-radius-xl:      20px;
  --t-radius-pill:    100px;

  --t-ease:           cubic-bezier(0.22, 1, 0.36, 1);
  --t-duration:       220ms;
}


*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

body {
  font-family:    var(--t-font-sans);
  font-size:      var(--t-text-base);
  line-height:    var(--t-leading-normal);
  color:          var(--t-text-primary);
  background:     var(--t-cream);
  margin:         0;
}

img,
svg {
  display: block;
  max-width: 100%;
}

a {
  color: inherit;
  text-decoration: none;
}


h1, h2, h3,
.t-display,
.t-headline {
  font-family:  var(--t-font-serif);
  font-weight:  500;
  line-height:  var(--t-leading-tight);
  color:        var(--t-text-primary);
  margin-top:   0;
}

h1, .t-h1 {
  font-size:   clamp(var(--t-text-4xl), 5.5vw, var(--t-text-hero));
  font-weight: 400;
  letter-spacing: -0.02em;
}

h2, .t-h2 {
  font-size:    clamp(var(--t-text-3xl), 4vw, var(--t-text-5xl));
  font-weight:  400;
  letter-spacing: -0.015em;
}

h3, .t-h3 {
  font-size:    clamp(var(--t-text-xl), 2.5vw, var(--t-text-2xl));
  font-weight:  500;
}

h4, .t-h4 {
  font-family:  var(--t-font-sans);
  font-size:    var(--t-text-base);
  font-weight:  500;
  line-height:  var(--t-leading-snug);
}

p {
  font-size:   var(--t-text-base);
  line-height: var(--t-leading-relaxed);
  color:       var(--t-text-muted);
  margin-top:  0;
}

.t-label,
.section-label {
  font-family:    var(--t-font-sans);
  font-size:      var(--t-text-xs);
  font-weight:    500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color:          var(--t-text-muted);
  margin-bottom:  16px;
  display:        block;
}

.t-quote {
  font-family:  var(--t-font-serif);
  font-size:    clamp(var(--t-text-2xl), 3vw, var(--t-text-4xl));
  font-weight:  400;
  font-style:   italic;
  line-height:  var(--t-leading-snug);
  color:        var(--t-text-on-dark);
}



/* Primary — solid coral */
.hs-button,
.hs-button.primary,
a.hs-button,
.t-btn-primary {
  display:          inline-flex;
  align-items:      center;
  gap:              8px;
  padding:          13px 28px;
  font-family:      var(--t-font-sans);
  font-size:        var(--t-text-sm);
  font-weight:      500;
  letter-spacing:   0.01em;
  color:            #ffffff !important;
  background:       var(--t-coral);
  border:           none;
  border-radius:    var(--t-radius-pill);
  cursor:           pointer;
  text-decoration:  none;
  transition:       background var(--t-duration) var(--t-ease),
                    transform  var(--t-duration) var(--t-ease);
}

.hs-button:hover,
.hs-button.primary:hover,
.t-btn-primary:hover {
  background:  var(--t-coral-hover);
  transform:   translateY(-1px);
}

.hs-button:active,
.t-btn-primary:active {
  transform: translateY(0);
}

.hs-button.secondary,
.t-btn-secondary {
  display:          inline-flex;
  align-items:      center;
  gap:              8px;
  padding:          12px 28px;
  font-family:      var(--t-font-sans);
  font-size:        var(--t-text-sm);
  font-weight:      500;
  color:            var(--t-text-primary);
  background:       transparent;
  border:           1.5px solid var(--t-border-strong);
  border-radius:    var(--t-radius-pill);
  cursor:           pointer;
  text-decoration:  none;
  transition:       border-color var(--t-duration) var(--t-ease),
                    background   var(--t-duration) var(--t-ease),
                    transform    var(--t-duration) var(--t-ease);
}

.hs-button.secondary:hover,
.t-btn-secondary:hover {
  border-color: var(--t-text-primary);
  background:   rgba(28, 27, 25, 0.04);
  transform:    translateY(-1px);
}

.t-btn-ghost-dark {
  color:        var(--t-text-on-dark);
  border-color: rgba(245, 242, 238, 0.3);
}

.t-btn-ghost-dark:hover {
  background:   rgba(245, 242, 238, 0.08);
  border-color: rgba(245, 242, 238, 0.6);
}


/* .content-wrapper,
.row-fluid,
.dnd-section > .dnd-column {
  max-width:   var(--t-container-max) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: var(--t-container-pad) !important;
  padding-right: var(--t-container-pad) !important;
} */


.dnd-section {
  padding-top:    var(--t-section-pad-y);
  padding-bottom: var(--t-section-pad-y);
}


.dnd-section.section-tight {
  padding-top:    var(--t-section-pad-y-sm);
  padding-bottom: var(--t-section-pad-y-sm);
}

.bg-cream       { background-color: var(--t-cream); }
.bg-cream-dark  { background-color: var(--t-cream-dark); }
.bg-white       { background-color: var(--t-white); }
.bg-dark        { background-color: var(--t-dark); }



.t-card {
  background:    var(--t-white);
  border:        1px solid var(--t-border);
  border-radius: var(--t-radius-lg);
  padding:       28px 28px 32px;
}

.t-card-title {
  font-family:  var(--t-font-sans);
  font-size:    var(--t-text-base);
  font-weight:  500;
  color:        var(--t-text-primary);
  margin:       0 0 8px;
  line-height:  var(--t-leading-snug);
}

.t-card-body {
  font-size:   var(--t-text-sm);
  line-height: var(--t-leading-relaxed);
  color:       var(--t-text-dark);
  margin:      0;
}

.t-card-dot {
  width:         10px;
  height:        10px;
  border-radius: 50%;
  background:    var(--t-coral);
  margin-bottom: 20px;
}

.t-stat {
  font-family:  var(--t-font-serif);
  font-size:    var(--t-text-4xl);
  font-weight:  400;
  color:        var(--t-text-primary);
  line-height:  1;
}

.t-stat-label {
  font-size:   var(--t-text-sm);
  color:       var(--t-text-muted);
  margin-top:  6px;
}


.header--main {
  background:   var(--t-cream) !important;
  border-bottom: 1px solid var(--t-border) !important;
  box-shadow:   none !important;
}

.navigation-primary > ul > li > a,
.hs-menu-wrapper > ul > li > a {
  font-family:   var(--t-font-sans) !important;
  font-size:     var(--t-text-sm) !important;
  font-weight:   400 !important;
  color:         var(--t-text-primary) !important;
  letter-spacing: 0;
}

.navigation-primary > ul > li > a:hover,
.hs-menu-wrapper > ul > li > a:hover {
  color: var(--t-coral) !important;
}


.navigation-primary .menu-item--cta a {
  background:    var(--t-coral) !important;
  color:         #ffffff !important;
  padding:       9px 20px !important;
  border-radius: var(--t-radius-pill) !important;
  font-size:     var(--t-text-sm) !important;
}

.navigation-primary .menu-item--cta a:hover {
  background: var(--t-coral-hover) !important;
}


.widget-type-rich_text h1,
.widget-type-rich_text h2,
.widget-type-rich_text h3,
.dnd_area h1,
.dnd_area h2,
.dnd_area h3 {
  font-family: var(--t-font-serif);
  font-weight: 400;
}


.section-header,
.section-heading {
  max-width: 640px;
}


.card-section .card {
  background:    var(--t-white) !important;
  border:        1px solid var(--t-border) !important;
  border-radius: var(--t-radius-lg) !important;
  box-shadow:    none !important;
  padding:       28px !important;
}

.card-section .card:hover {
  border-color: var(--t-border-strong) !important;
  transform:    translateY(-2px);
  transition:   transform var(--t-duration) var(--t-ease),
                border-color var(--t-duration) var(--t-ease);
}

.card-section .card__title {
  font-family:  var(--t-font-sans) !important;
  font-size:    var(--t-text-base) !important;
  font-weight:  500 !important;
  color:        var(--t-text-primary) !important;
}

.card-section .card__body {
  font-size:  var(--t-text-sm) !important;
  color:      var(--t-text-muted) !important;
  line-height: var(--t-leading-relaxed) !important;
}

.card-section .card__icon:empty {
  display: none !important;
}


.accordion__title {
  font-family:  var(--t-font-sans) !important;
  font-size:    var(--t-text-base) !important;
  font-weight:  500 !important;
  color:        var(--t-text-primary) !important;
  padding:      20px 0 !important;
  border-top:   1px solid var(--t-border) !important;
  border-bottom: none !important;
  background:   transparent !important;
}

.accordion__title:hover {
  color: var(--t-coral) !important;
}

.accordion__body {
  font-size:    var(--t-text-sm) !important;
  color:        var(--t-text-muted) !important;
  line-height:  var(--t-leading-relaxed) !important;
  padding:      0 0 20px !important;
  border:       none !important;
  background:   transparent !important;
}

.accordion__toggle {
  color: var(--t-coral) !important;
}


.stats-section .stat__number {
  font-family:  var(--t-font-serif) !important;
  font-size:    clamp(var(--t-text-3xl), 4vw, var(--t-text-4xl)) !important;
  font-weight:  400 !important;
  color:        var(--t-text-primary) !important;
}

.stats-section .stat__label {
  font-size:  var(--t-text-sm) !important;
  color:      var(--t-text-muted) !important;
}


.team-section .team-member__name {
  font-family:  var(--t-font-sans) !important;
  font-weight:  500 !important;
  font-size:    var(--t-text-base) !important;
}

.team-section .team-member__role {
  font-size:  var(--t-text-sm) !important;
  color:      var(--t-text-muted) !important;
}

.team-section .team-member__photo {
  border-radius: var(--t-radius-lg) !important;
}

.cta-section--dark {
  background-color: var(--t-dark) !important;
}

.cta-section--dark h2,
.cta-section--dark .cta__title {
  font-family: var(--t-font-serif) !important;
  color:       var(--t-text-on-dark) !important;
  font-weight: 400 !important;
}

.cta-section--dark p,
.cta-section--dark .cta__body {
  color: var(--t-text-muted-dark) !important;
}



.footer--main {
  background:    var(--t-dark) !important;
  border-top:    1px solid rgba(245, 242, 238, 0.08) !important;
  padding-top:   60px !important;
  padding-bottom: 40px !important;
}

.footer__nav a,
.footer--main a {
  font-size:   var(--t-text-sm) !important;
  color:       var(--t-text-muted-dark) !important;
  transition:  color var(--t-duration) var(--t-ease) !important;
}

.footer__nav a:hover,
.footer--main a:hover {
  color: var(--t-text-on-dark) !important;
}

.footer__copyright {
  font-size:  var(--t-text-xs) !important;
  color:      var(--t-text-light) !important;
  margin-top: 40px !important;
}

.text-left    { text-align: left; }
.text-center  { text-align: center; }

.text-primary { color: var(--t-text-primary); }
.text-muted   { color: var(--t-text-muted); }
.text-coral   { color: var(--t-coral); }
.text-on-dark { color: var(--t-text-on-dark); }

.mt-sm  { margin-top: 16px; }
.mt-md  { margin-top: 32px; }
.mt-lg  { margin-top: 48px; }
.mb-sm  { margin-bottom: 16px; }
.mb-md  { margin-bottom: 32px; }
.mb-lg  { margin-bottom: 48px; }

.t-divider {
  border: none;
  border-top: 1px solid var(--t-border);
  margin: 0;
}

.t-highlight {
  color: var(--t-coral);
  font-style: italic;
}


@media (max-width: 1024px) {
  :root {
    --t-section-pad-y:    60px;
    --t-section-pad-y-sm: 40px;
    --t-container-pad:    28px;
  }
}

@media (max-width: 768px) {
  :root {
    --t-section-pad-y:    48px;
    --t-section-pad-y-sm: 32px;
    --t-container-pad:    20px;
  }

  h1, .t-h1 {
    font-size: var(--t-text-3xl);
    letter-spacing: -0.01em;
  }

  h2, .t-h2 {
    font-size: var(--t-text-2xl);
  }

  /* Stack nav on mobile */
  .header--main .navigation-primary {
    background: var(--t-cream) !important;
  }
}

@media (max-width: 480px) {
  :root {
    --t-container-pad: 16px;
  }
}


@media print {
  :root {
    --t-text-primary: #000000;
    --t-text-muted:   #444444;
  }

  .header--main,
  .footer--main {
    display: none;
  }
}


/* ============================================================
   SECTION 1  HERO - HOME PAGE
   ============================================================ */
.terrific-hero.grid-pattern-bg,
.terrific-hero {
  background:
    radial-gradient(
      ellipse at 60% 50%,
      rgba(248, 180, 160, 0.5) 0%,
      rgba(207, 96, 96, 0) 60%
    ),
    radial-gradient(
      ellipse at 75% 40%,
      rgba(244, 188, 210, 0.55) 0%,
      rgba(186, 74, 74, 0) 89%
    ),
    linear-gradient(
      135deg,
      #FBEDE0 0%,
      #F7D9DF 45%,
      #F0C9D6 75%,
      #EEDDE8 100%
    ) !important;
}

.terrific-hero .hero-title-gradient {
  font-family:    var(--t-font-serif) !important;
  font-size:      clamp(2.5rem, 5vw, 4.25rem) !important;
    font-style: italic;
  line-height:    1.1 !important;
  letter-spacing: -0.072rem !important;
  color:          var(--t-text-primary) !important;
  text-align:     left !important;
  max-width:      580px;
  margin-bottom:  24px !important;
  background:     none !important;
  -webkit-background-clip: unset !important;
  -webkit-text-fill-color: unset !important;
}
@media (min-width: 1024px) {
  .terrific-hero .hero-list {
      width: 35% !important;
  }
}
@media (min-width: 787px) {
  .terrific-hero .hero-list {
      width: 50% !important;
  }
}
.terrific-hero .hero-list {
      max-width: none !important;
    list-style:    none;
    padding:       0;
    margin:        0 0 36px;
    display:       flex;
    flex-direction: column;
    gap:           14px;
  }
.terrific-hero .hero-list li {
  font-family:  var(--t-font-sans);
  font-size:    16px !important;
  line-height:  1.6;
  color:        var(--t-text-primary);
  padding-left: 24px;
  position:     relative;
}

/* Em-dash marker */
.terrific-hero .hero-list li::before {
  content:    '—';
  position:   absolute;
  left:       0;
  color:      var(--t-text-muted);
  font-size:  0.875rem;
}

.terrific-hero .c-cta-group {
  justify-content: flex-start !important;
}

/* Primary button coral radial */
.cta-primary{
   display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 14px 28px !important;
  background: radial-gradient(ellipse at top left, #EE7944 0%, #E92B6D 58%, #C9501E 100%) !important;
  color: #fff;
  font-size: 15px !important;
  font-weight: 500;
  border: none;
  border-radius: 8px;
  cursor: pointer;
  letter-spacing: 0.3px;
  text-decoration: none;
  transition: opacity 0.2s ease, transform 0.2s ease;
  box-shadow: none !important;
  text-transform: capitalize !important;
}

.hs-button {
  display: inline-flex !important;
  align-items: center;
  gap: 6px;
  padding: 14px 22px !important;
  background: linear-gradient(90deg, #EE7944 0%, #E92B6D 55%, #C9501E 100%) !important;
  color: #fff;
  font-size: 15px !important;
  font-weight: 500;
  border: none !important;
  border-radius: 8px !important;
  cursor: pointer !important;
  letter-spacing: 0.3px !important;
  text-decoration: none !important;
  transition: opacity 0.2s ease, transform 0.2s ease !important;
  box-shadow: none !important;
  text-transform: capitalize !important;
}

.hs-button::after {
  content: '→';
  font-size: 16px;
  line-height: 1;
}
/* Secondary button dark radial */
.std-btn-2.standard-btn {
  display:         inline-flex !important;
  align-items:     center !important;
  gap:             8px !important;
  background: radial-gradient(ellipse at top left, #696969 0%, #433C3C 60%, #3C3C3C 100%);
  color:           #ffffff !important;
  border:          none !important;
  border-radius:   10px !important;
  font-family:     var(--t-font-sans) !important;
  font-size:       0.9375rem !important;
  font-weight:     500 !important;
  padding:         13px 28px !important;
  text-transform: caption !important;
  transition:     opacity 0.2s ease, transform 0.2s ease; !important;
  text-transform: capitalize !important;
}
.std-btn-2.standard-btn:hover,
.hs-button:hover {
  transform: scale(1.05);
}

/*  Arrow icons  */
.terrific-hero .standard-btn svg {
  display:     inline-block !important;
  width:       13px !important;
  height:      13px !important;
  fill:        #ffffff !important;
  flex-shrink: 0 !important;
}

/* Align left */
.terrific-hero .c-justify-center {
  justify-content: flex-start !important;
}

/* Partner badge pill */
.terrific-hero .c-in-1 p {
  display:        inline-flex !important;
  align-items:    center !important;
  gap:            8px !important;
  padding:        7px 16px !important;
  background:     rgba(255, 255, 255, 0.5) !important;
  border:         1px solid rgba(255, 255, 255, 0.8) !important;
  border-radius:  100px !important;
  font-family:    var(--t-font-sans) !important;
  font-size:      10px !important;
  font-weight:    400 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  color:          rgba(26,26,26,0.77) !important;
}

/* Red dot before badge text */
.terrific-hero .c-in-1 p::before {
  content:          '' !important;
  display:          inline-block !important;
  width:            7px !important;
  height:           7px !important;
  border-radius:    50% !important;
  background:       #D94F3A !important;
  flex-shrink:      0 !important;
}

.terrific-hero .c-cta-group {
  margin-bottom:   16px !important;
}

/* Helper text below buttons  */
.terrific-hero .c-in-4 p {
  font-family: var(--t-font-sans) !important;
  font-size:   0.8125rem !important;
  line-height: 1.5 !important;
  color:       var(--t-text-muted) !important;
  margin:      0 !important;
}

/* ============================================================
   SHARED SECTION BASE (used by pains, audience, services)
   ============================================================ */
.t-section {
  max-width: 1160px;
  margin:    0 auto;
  padding:   80px 40px;
}

.t-section-header {
  margin-bottom: 56px;
}

.t-section-label {
  font-family:    var(--t-font-jetbrains);
  font-size:      0.75rem;
  font-weight:    500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color:          var(--t-text-muted);
  display:        block;
  margin-bottom:  16px;
}

.t-section-heading {
  font-family:    var(--t-font-serif);
  font-size:      clamp(2rem, 4vw, 3.25rem);
  font-weight:    400;
  font-style:     italic;
  line-height:    1.1;
  letter-spacing: -0.02em;
  color:          var(--t-text-primary);
  margin:         0;
  max-width:      900px;
}

.t-section-heading + .t-section-intro {
  margin-top: 20px;
}

.t-section-intro {
  font-family: var(--t-font-sans) !important;
  font-size:   1rem !important;
  line-height: 1.75 !important;
  color:       var(--t-text-muted) !important;
  max-width:   600px;
  margin:      0 !important;
}

.t-grid {
  display:               grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap:                   24px;
}

.t-grid--2 {
  grid-template-columns: 1fr 1fr;
}

.t-card {
  background:     #ffffff;
  border:         1px solid var(--t-border);
  border-radius:  12px;
  padding:        24px;
  display:        flex;
  flex-direction: column;
  transition:     border-color 220ms ease, transform 220ms ease;
  justify-content: space-between;
  height:          350px;
  transition:      border-color 220ms ease, transform 220ms ease;
  overflow:        hidden;
}
.t-card:hover {
  border-color: var(--t-border-strong);
  transform:    translateY(-2px);
}

.t-card--lg {
  padding: 36px 36px 40px;
}

.t-card-title {
  font-family:   var(--t-font-sans) !important;
  font-size:     20px !important;
  font-weight:   500 !important;
  line-height:   1.4 !important;
  color:         var(--t-text-primary) !important;
  margin:        0 0 14px !important;
  letter-spacing: 0.8px;
}

.t-card-body {
  font-family:  var(--t-font-sans);
  font-size:    13px;
  line-height:  1.7;
  color:        var(--t-text-dark);
  margin:       0;
  flex-grow:    1;
  letter-spacing: 0.6px;
}

.t-card-icon {
  width:           40px;
  height:          40px;
  border-radius:   8px;
  background:      var(--t-cream-light);
  color:           var(--t-magenta);
  display:         flex;
  align-items:     center;
  justify-content: center;
  margin-bottom:   24px;
}

.t-card-icon--sm {
  width:  36px;
  height: 36px;
}

.t-card-icon svg {
  width:  20px;
  height: 20px;
}

.t-card-icon--sm svg {
  width:  18px;
  height: 18px;
}

.t-card-divider {
  border-top: 1px solid var(--t-border);
  margin-top:     8px;
}

.t-card-tags {
  font-family:    var(--t-font-jetbrains);
  font-size:      10px !important;
  font-weight:    500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color:          var(--t-text-muted);
  display:        block;
  line-height:    1.6;
}

.t-card-outcome {
  display:     flex;
  gap:         10px;
  font-family: var(--t-font-sans);
  font-size:   12px;
  line-height: 1.6;
  color:       var(--t-text-primary);
  padding-top: 16px;
  margin-top:  24px;
  border-top:  1px solid var(--t-border);
}

.t-card-outcome-arrow {
  color:       var(--t-magenta);
  font-weight: 500;
  flex-shrink: 0;
}

.t-card-num {
  font-family:   var(--t-font-nunito);
  font-size:     34px;
  font-weight:   400;
  color:         var(--t-coral);
  display:       block;
  margin-bottom: 24px;
}

.t-section-footer {
  font-family: var(--t-font-sans) !important;
  font-size:   1rem !important;
  line-height: 1.75 !important;
  color:       var(--t-text-muted) !important;
  max-width:   720px;
  margin:      48px 0 0 !important;
}

@media (max-width: 1024px) {
  .t-grid {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 640px) {
  .t-section {
    padding: 56px 20px;
  }

  .t-grid,
  .t-grid--2 {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .t-card--lg {
    padding: 28px 24px 32px;
  }
}
/* ============================================================
   HOME PAGE TESTIMONIAL SCROLLER
   ============================================================ */
.hhs-testimonial-scroller-mod {
  background:     var(--t-dark) !important;
  padding-top:    100px !important;
  padding-bottom: 100px !important;
  position:       relative;
}

.hhs-testimonial-scroller-mod .container {
/*   max-width:     1160px !important; */
/*   margin:        0 auto !important; */
  padding:       0px !important;
}

.hhs-testimonial-scroller-mod .content-group {
  padding-left: 100px !important;
  max-width:    650px;
}

.hhs-testimonial-scroller-mod .icon-con {
  margin-bottom: 28px;
}

.hhs-testimonial-scroller-mod .icon-con svg {
  width:  32px !important;
  height: 32px !important;
  fill:   var(--t-magenta) !important;
}

.hhs-testimonial-scroller-mod .quote-con {
  font-family:  var(--t-font-serif) !important;
  font-size:    clamp(1.5rem, 2.5vw, 2.25rem) !important;
  font-weight:  400 !important;
  font-style:   normal !important;
  line-height:  1.3 !important;
  color:        var(--t-text-on-dark, #F5F2EE) !important;
  margin:       0 0 36px !important;
  padding:      0 !important;
  border:       none !important;
  background:   transparent !important;
  max-width:    640px;
  letter-spacing: -0.01em;
}

.hhs-testimonial-scroller-mod .test-name {
  font-family:  var(--t-font-sans) !important;
  font-size:    0.875rem !important;
  font-weight:  500 !important;
  color:        var(--t-text-on-dark) !important;
  margin-bottom: 4px !important;
}

.hhs-testimonial-scroller-mod .test-title {
  font-family:    var(--t-font-sans) !important;
  font-size:      0.75rem !important;
  font-weight:    400 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  color:          var(--t-text-muted-dark, #9E9B95) !important;
}

.hhs-testimonial-scroller-mod .slick-prev,
.hhs-testimonial-scroller-mod .slick-next {
  width:         40px !important;
  height:        40px !important;
  border-radius: 50% !important;
  border:        1px solid rgba(245, 242, 238, 0.2) !important;
  background:    transparent !important;
  color:         transparent !important;
  font-size:     0 !important;
  z-index:       2;
  transition:    border-color 220ms ease, background 220ms ease;
    
}
#hs_cos_wrapper_widget_1777351227217 .scrolling-testimonials button.slick-prev{
    left: -50px !important;
    top: 140px !important;
}
#hs_cos_wrapper_widget_1777351227217 .scrolling-testimonials button.slick-next{
    right: -30px !important;
    top: 140px !important;
}
.hhs-testimonial-scroller-mod .slick-prev:hover,
.hhs-testimonial-scroller-mod .slick-next:hover {
  border-color: var(--t-text-on-dark) !important;
  background:   rgba(245, 242, 238, 0.05) !important;
}

.hhs-testimonial-scroller-mod .slick-prev::before,
.hhs-testimonial-scroller-mod .slick-next::before {
  content:    '';
  display:    block;
  width:      8px;
  height:     8px;
  border-top: 1.5px solid var(--t-text-on-dark);
  border-right: 1.5px solid var(--t-text-on-dark);
  position:   absolute;
  top:        50%;
  left:       50%;
  opacity:    1 !important;
}

.hhs-testimonial-scroller-mod .slick-prev::before {
  transform: translate(-50%, -50%) rotate(-180deg);
}

.hhs-testimonial-scroller-mod .slick-next::before {
  transform: translate(-50%, -50%) rotate(180deg);
}

.hhs-testimonial-scroller-mod .slick-prev {
  top:    40px !important;
  right:  100px !important;
  left:   auto !important;
}

.hhs-testimonial-scroller-mod .slick-next {
  top:   40px !important;
  right: 40px !important;
}

.hhs-testimonial-scroller-mod .slick-dots {
  display:         flex !important;
  justify-content: center !important;
  gap:             8px;
  margin:          48px 0 0 !important;
  padding:         0;
  list-style:      none;
  bottom:          auto !important;
  position:        relative !important;
}

.hhs-testimonial-scroller-mod .slick-dots li {
  width:  auto !important;
  height: auto !important;
  margin: 0 !important;
}

.hhs-testimonial-scroller-mod .slick-dots li button {
  width:         32px !important;
  height:        3px !important;
  border-radius: 2px !important;
  background:    rgba(245, 242, 238, 0.2) !important;
  font-size:     0 !important;
  padding:       0 !important;
  border:        none !important;
  cursor:        pointer;
  transition:    background 220ms ease;
}

.hhs-testimonial-scroller-mod .slick-dots li button::before {
  display: none !important;
}

.hhs-testimonial-scroller-mod .slick-dots li.slick-active button {
  background: var(--t-text-on-dark) !important;
  width:      48px !important;
}

@media (max-width: 768px) {
  .hhs-testimonial-scroller-mod {
    padding-top:    64px !important;
    padding-bottom: 64px !important;
  }

  .hhs-testimonial-scroller-mod .container {
    padding: 0 20px !important;
  }

  .hhs-testimonial-scroller-mod .content-group {
    padding-left: 0 !important;
  }

  .hhs-testimonial-scroller-mod .slick-prev {
    right: 80px !important;
  }
}
/* ============================================================
   FAQ ACCORDION
   ============================================================ */

.hhs-accordion-mod {
  background:     var(--t-cream) !important;
  padding-top:    40px !important;
  padding-bottom: 80px !important;
}

.hhs-accordion-mod .container {
  max-width: 880px !important;
  margin:    0 auto !important;
  padding:   0 40px !important;
}

/* Hide the H3 inside the accordion — we use our own heading above */
.hhs-accordion-mod .hhs-rich-text > h3 {
  display: none !important;
}

/* Accordion list reset */
.hhs-accordion-mod .accordion-controls {
  list-style:  none !important;
  padding:     0 !important;
  margin:      0 !important;
  border-top:  1px solid var(--t-border);
}

.hhs-accordion-mod .accordion-controls > li {
  border-bottom: 1px solid var(--t-border);
  margin:        0 !important;
  padding:       0 !important;
}

/* Question row */
.hhs-accordion-mod .accordion-title {
  display:         flex !important;
  align-items:     center !important;
  justify-content: space-between !important;
  padding:         24px 0 !important;
  text-decoration: none !important;
  color:           var(--t-text-primary) !important;
  cursor:          pointer;
  position:        relative;
  transition:      color 220ms ease;
}

.hhs-accordion-mod .accordion-title:hover {
  color: var(--t-magenta) !important;
}

.hhs-accordion-mod .accordion-title h4 {
  font-family:   var(--t-font-sans) !important;
  font-size:     1rem !important;
  font-weight:   500 !important;
  line-height:   1.5 !important;
  color:         inherit !important;
  margin:        0 !important;
  padding-right: 32px;
  flex:          1;
}

.hhs-accordion-mod .accordion-title::before,
.hhs-accordion-mod .accordion-title svg,
.hhs-accordion-mod .accordion-title .fa,
.hhs-accordion-mod .accordion-title i {
  display: none !important;
}

.hhs-accordion-mod .accordion-title::after {
  content:         '+' !important;
  font-family:     var(--t-font-sans) !important;
  font-size:       1.5rem !important;
  font-weight:     300 !important;
  color:           var(--t-text-primary) !important;
  background:      transparent !important;
  width:           24px !important;
  height:          24px !important;
  border-radius:   50% !important;
  display:         flex !important;
  align-items:     center !important;
  justify-content: center !important;
  flex-shrink:     0 !important;
  border:          none !important;
  transform:       none !important;
  position:        static !important;
  transition:      background 220ms ease, color 220ms ease !important;
}

.hhs-accordion-mod .accordion-title.active::after {
  content:    '−' !important;
  font-size:  1rem !important;
  background: var(--t-magenta) !important;
  color:      #ffffff !important;
}

.hhs-accordion-mod .hhs-accordion-content {
  display:    none;
  padding:    0 15px 24px !important;
  border:     none !important;
  background: transparent !important;
}

.hhs-accordion-mod .hhs-accordion-content[aria-hidden="false"] {
  display: block;
}

.hhs-accordion-mod .hhs-accordion-content p,
.hhs-accordion-mod .hhs-accordion-content span {
  font-family: var(--t-font-sans) !important;
  font-size:   0.9375rem !important;
  line-height: 1.7 !important;
  color:       var(--t-text-muted) !important;
  background:  transparent !important;
  margin:      0 0 12px !important;
  max-width:   720px;
}

.hhs-accordion-mod .hhs-accordion-content p:last-child {
  margin-bottom: 0 !important;
}

@media (max-width: 640px) {
  .hhs-accordion-mod .container {
    padding: 0 20px !important;
  }

  .hhs-accordion-mod .accordion-title h4 {
    font-size: 0.9375rem !important;
  }
}
/* ============================================================
    BOTTOM CTA
   ============================================================ */

.t-section--cta {
  padding-top:    0px !important;
  padding-bottom: 50px !important;
  text-align:     center;
}

.t-section-heading--on-dark {
  color: var(--t-text-on-dark) !important;
}

.t-section--cta .t-section-heading {
  margin: 0 auto 32px !important;
  max-width: 720px;
}

.t-section-cta-body {
  font-family: var(--t-font-sans) !important;
  font-size:   0.9375rem !important;
  line-height: 1.7 !important;
  color:       var(--t-text-muted-dark) !important;
  max-width:   500px;
  text-align: center;
  margin:      0 auto 0 !important;
}

.t-section-cta-helper {
    text-align: center;
  font-family:    var(--t-font-sans) !important;
  font-size:      0.6875rem !important;
  font-weight:    500 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color:          var(--t-text-muted-dark) !important;
  margin:         24px auto 0 !important;
}

/* ============================================================
   SOLUTION STEPPER
   ============================================================ */
#hs_cos_wrapper_widget_1777435068349 .panel{
    box-shadow: none !important;
}
.hhs-tab-mod {
  padding-top:    80px !important;
  padding-bottom: 80px !important;
}

.hhs-tab-mod .container {
  max-width: 1080px !important;
  margin:    0 auto !important;
  padding:   0 40px !important;
}

.hhs-tab-mod .hhs-tab-content {
  background:    #ffffff !important;
  border:        1px solid var(--t-border) !important;
  border-radius: 16px !important;
  padding:       48px 48px 40px !important;
  box-shadow:    0 2px 8px rgba(28, 27, 25, 0.04);
}

.hhs-tab-mod .hhs-tab-wrapper {
  list-style:      none !important;
  padding:         0 !important;
  margin:          0 0 48px !important;
  display:         flex !important;
  justify-content: space-between !important;
  align-items:     flex-start !important;
  position:        relative;
  gap:             0 !important;
}

.hhs-tab-mod .hhs-tab-wrapper::before {
  content:    '';
  position:   absolute;
  top:        16px;
  left:       16px;
  right:      16px;
  height:     1px;
  background: var(--t-border);
  z-index:    1;
}

.hhs-tab-mod .hhs-tab-wrapper > li {
  flex:            1;
  display:         flex;
  justify-content: center;
  position:        relative;
  z-index:         2;
  margin:          0 !important;
  border:          none;
}

.hhs-tab-mod .hhs-tab-wrapper button {
  background:      transparent !important;
  border:          none !important;
  cursor:          pointer;
  padding:         0 !important;
  font-family:     var(--t-font-sans) !important;
  font-size:       0.8125rem !important;
  font-weight:     500 !important;
  color:           var(--t-text-muted) !important;
  display:         flex !important;
  flex-direction:  column !important;
  align-items:     center !important;
  gap:             10px !important;
  position:        relative;
  text-align:      center;
  transition:      color 220ms ease;
  font-size:       0 !important;
}
.hhs-tab-mod .hhs-tab-wrapper button::before {
  content:         attr(data-step) '';
  display:         flex;
  align-items:     center;
  justify-content: center;
  width:           32px;
  height:          32px;
  border-radius:   50%;
  background:      #ffffff;
  border:          1px solid var(--t-border);
  font-family:     var(--t-font-sans);
  font-size:       0.6875rem;
  font-weight:     500;
  color:           var(--t-text-muted);
  z-index:         2;
  transition:      background 220ms ease, color 220ms ease, border-color 220ms ease;
}

.hhs-tab-mod .hhs-tab-wrapper li:nth-child(1) button::before { content: '01'; }
.hhs-tab-mod .hhs-tab-wrapper li:nth-child(2) button::before { content: '02'; }
.hhs-tab-mod .hhs-tab-wrapper li:nth-child(3) button::before { content: '03'; }
.hhs-tab-mod .hhs-tab-wrapper li:nth-child(4) button::before { content: '04'; }

.hhs-tab-mod .hhs-tab-wrapper button::after {
  font-family: var(--t-font-sans);
  font-size:   0.8125rem;
  font-weight: 500;
  color:       var(--t-text-muted);
  transition:  color 220ms ease;
}

.hhs-tab-mod .hhs-tab-wrapper li:nth-child(1) button::after { content: 'Discover'; }
.hhs-tab-mod .hhs-tab-wrapper li:nth-child(2) button::after { content: 'Design';   }
.hhs-tab-mod .hhs-tab-wrapper li:nth-child(3) button::after { content: 'Build';    }
.hhs-tab-mod .hhs-tab-wrapper li:nth-child(4) button::after { content: 'Scale';    }

.hhs-tab-mod .hhs-tab-wrapper button.is-active::before {
  background:   var(--t-coral) !important;
  border-color: var(--t-coral) !important;
  color:        #ffffff !important;
}

.hhs-tab-mod .hhs-tab-wrapper button.is-active::after {
  color:       var(--t-text-primary) !important;
  font-weight: 600;
}

.hhs-tab-mod .hhs-tab-wrapper button:hover::before {
  border-color: var(--t-text-primary);
}

.hhs-tab-mod .hhs-panel-wrapper {
  margin-top: 0;
}

.hhs-tab-mod .panel {
  display: none;
}

.hhs-tab-mod .panel.is-active {
  display: block;
}

.t-step {
  display:               grid;
  grid-template-columns: 1fr 1fr;
  gap:                   48px;
  align-items:           center;
}

.t-step-image {
  background:    var(--t-cream-dark, #F2EDE6);
  border-radius: 12px;
  overflow:      hidden;
  padding:       32px;
  display:       flex;
  align-items:   center;
  justify-content: center;
  aspect-ratio:  4 / 3;
}

.t-step-image img {
  max-width:  100%;
  max-height: 100%;
  width:      auto;
  height:     auto;
  display:    block;
}

.t-step-content {
  padding: 0;
}

.t-step-eyebrow {
  font-family:    var(--t-font-sans) !important;
  font-size:      0.75rem !important;
  font-weight:    500 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color:          var(--t-coral) !important;
  display:        block !important;
  margin-bottom:  16px !important;
}

.t-step-title {
  font-family:    var(--t-font-serif) !important;
  font-size:      clamp(1.75rem, 3vw, 2.5rem) !important;
  font-weight:    400 !important;
  line-height:    1.1 !important;
  letter-spacing: -0.02em !important;
  color:          var(--t-text-primary) !important;
  margin:         0 0 20px !important;
}

.t-step-body {
  font-family:  var(--t-font-sans) !important;
  font-size:    0.9375rem !important;
  line-height:  1.7 !important;
  color:        var(--t-text-muted) !important;
  margin:       0 0 24px !important;
  max-width:    480px;
}

.t-step-tags {
  display:   flex;
  flex-wrap: wrap;
  gap:       8px;
}

.t-step-pill {
  display:        inline-flex;
  padding:        6px 14px;
  background:     var(--t-cream-dark, #F2EDE6);
  border-radius:  100px;
  font-family:    var(--t-font-sans);
  font-size:      0.75rem;
  font-weight:    500;
  color:          var(--t-text-primary);
}

@media (max-width: 768px) {
  .hhs-tab-mod .hhs-tab-content {
    padding: 32px 24px !important;
  }

  .hhs-tab-mod .hhs-tab-wrapper {
    margin-bottom: 32px !important;
  }

  .hhs-tab-mod .hhs-tab-wrapper button::after {
    display: none;
  }

  .t-step {
    grid-template-columns: 1fr;
    gap: 32px;
  }

  .t-step-image {
    aspect-ratio: 16 / 10;
    padding: 20px;
  }
}
/* ============================================================
   TEAM
   ============================================================ */

.t-team {
  display:               grid;
  grid-template-columns: 1fr 1fr;
  gap:                   80px;
  align-items:           start;
  margin-top:            32px;
}

.t-team-bio p {
  font-family: var(--t-font-sans) !important;
  font-size:   0.9375rem !important;
  line-height: 1.75 !important;
  color:       var(--t-text-muted) !important;
  margin:      0 0 20px !important;
  max-width:   460px;
}

.t-team-bio p:last-child {
  margin-bottom: 0 !important;
}

.t-team-portraits {
  display:         flex;
  gap:             20px;
  justify-content: flex-start;
  align-items:     flex-start;
}

.t-team-card {
  margin:    0 !important;
  flex:      1;
  max-width: 240px;
  position:  relative;
}

.t-team-card--offset {
  margin-top: 32px !important;
  max-width:  220px !important;
}

.t-team-photo {
  width:         100%;
  aspect-ratio:  3 / 4;
  border-radius: 12px;
  overflow:      hidden;
}

.t-team-photo::after {
  content:    '';
  position:   absolute;
  inset:      0;
  background: linear-gradient(
    160deg,
    rgba(217, 79, 58, 0.2) 0%,
    rgba(233, 43, 109, 0.15) 100%
  );
  mix-blend-mode: multiply;
  pointer-events: none;
}

.t-team-photo img {
  width:           100%;
  height:          100% !important;
  object-fit:      cover;
  object-position: center;
  display:         block;
}

@media (max-width: 768px) {
  .t-team {
    grid-template-columns: 1fr;
    gap: 40px;
  }

  .t-team-portraits {
    gap: 16px;
  }

  .t-team-card--offset {
    margin-top: 24px !important;
  }
}

@media (max-width: 480px) {
  .t-team-portraits {
    flex-direction: column;
    align-items:    stretch;
  }

  .t-team-card,
  .t-team-card--offset {
    max-width:  100% !important;
    margin-top: 0 !important;
  }
}
/* ============================================================
   FOOTER
   ============================================================ */
footer.footer,
.hhs-footer-mod {
  background:     var(--t-dark) !important;
  color:          var(--t-text-on-dark) !important;
  padding-top:    80px !important;
  padding-bottom: 32px !important;
}

.hhs-footer-mod .container {
  max-width: 1160px !important;
  margin:    0 auto !important;
  padding:   0 40px !important;
}

.t-footer-extras {
  max-width: 1160px;
  margin:    0 auto;
  padding:   0 40px;
  display:   grid;
  gap:       60px;
}

.t-footer-brand {
  max-width: 280px;
}

.t-footer-brand-tag {
  display:     inline-flex;
  align-items: center;
  gap:         8px;
  padding:     6px 10px 6px 6px;
  background:  var(--t-cream);
  color:       var(--t-text-primary);
  border-radius: 6px;
  margin-bottom: 16px;
}

.t-footer-brand-icon {
  width:           20px;
  height:          20px;
  background:      var(--t-text-primary);
  color:           var(--t-cream);
  border-radius:   3px;
  display:         flex;
  align-items:     center;
  justify-content: center;
  font-family:     var(--t-font-serif);
  font-size:       0.75rem;
  font-weight:     500;
}

.t-footer-brand-name {
  font-family: var(--t-font-sans);
  font-size:   0.8125rem;
  font-weight: 500;
}

.t-footer-tagline {
  font-family:   var(--t-font-sans) !important;
  font-size:     0.875rem !important;
  line-height:   1.55 !important;
  color:         var(--t-text-on-dark) !important;
  margin:        0 0 24px !important;
}

.t-footer-badges {
  display:        flex;
  flex-direction: column;
  gap:            8px;
  margin-bottom:  24px;
}

.t-footer-badge {
  display:        inline-flex;
  align-items:    center;
  gap:            8px;
  padding:        7px 14px;
  background:     var(--t-dark-secondary);
  border:         1px solid rgba(245, 242, 238, 0.08);
  border-radius:  100px;
  font-family:    var(--t-font-sans);
  font-size:      0.75rem;
  color:          var(--t-text-on-dark);
  width:          fit-content;
}

.t-footer-badge::before {
  content:       '';
  width:         6px;
  height:        6px;
  border-radius: 50%;
  background:    var(--t-magenta);
  flex-shrink:   0;
}

.t-footer-note {
  padding:       16px 18px;
  background:    var(--t-dark-secondary);
  border:        1px solid rgba(245, 242, 238, 0.08);
  border-radius: 8px;
  font-family:   var(--t-font-sans);
  font-size:     0.8125rem;
  line-height:   1.6;
  color:         var(--t-text-muted-dark);
  max-width:     280px;
}

.t-footer-note strong {
  color:                 var(--t-text-on-dark);
  font-weight:           400;
}

.hhs-footer-mod .hhs-foot-nav-cols {
  margin-top:    48px;
  padding-bottom: 48px;
  border-bottom: 1px solid rgba(245, 242, 238, 0.08);
}

.hhs-footer-mod .col-title {
  font-family:    var(--t-font-sans) !important;
  font-size:      0.6875rem !important;
  font-weight:    500 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  color:          var(--t-text-muted-dark) !important;
  margin-bottom:  20px !important;
}

.hhs-footer-mod .hhs-col-content ul {
  list-style: none !important;
  padding:    0 !important;
  margin:     0 !important;
  display:    flex;
  flex-direction: column;
  gap:        12px;
}

.hhs-footer-mod .hhs-col-content a {
  font-family:     var(--t-font-sans) !important;
  font-size:       0.875rem !important;
  color:           var(--t-text-on-dark) !important;
  text-decoration: none !important;
  transition:      color 220ms ease;
}

.hhs-footer-mod .hhs-col-content a:hover {
  color: var(--t-magenta) !important;
}

.t-footer-cities {
  display:               grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap:                   16px;
  margin-top:            48px;
  position:              relative;
}

.t-footer-cities::before {
  content:        'Terrific';
  position:       absolute;
  bottom:         -20px;
  left:           50%;
  transform:      translateX(-50%);
  font-family:    var(--t-font-serif);
  font-style:     italic;
  font-size:      9rem;
  font-weight:    400;
  color:          rgba(245, 242, 238, 0.04);
  pointer-events: none;
  white-space:    nowrap;
  z-index:        0;
}

.t-footer-city {
  position:       relative;
  z-index:        1;
  background:     var(--t-dark-secondary);
  border:         1px solid rgba(245, 242, 238, 0.08);
  border-radius:  12px;
  padding:        16px 18px 16px;
  display:        flex;
  flex-direction: column;
  gap:            12px;
}

.t-footer-city-clock {
  height:        50px;
  border-radius: 6px;
  background:    rgba(245, 242, 238, 0.02);
  position:      relative;
  overflow:      hidden;
}

.t-footer-city-clock::before {
  content:    '';
  position:   absolute;
  top:        50%;
  left:       16px;
  right:      16px;
  height:     1px;
  background: rgba(245, 242, 238, 0.12);
  transform:  translateY(-50%);
}

.t-footer-city-clock::after {
  content:       '';
  position:      absolute;
  top:           50%;
  left:          55%;
  width:         8px;
  height:        8px;
  border-radius: 50%;
  background:    var(--t-magenta);
  transform:     translate(-50%, -50%);
  box-shadow:    0 0 12px rgba(233, 43, 109, 0.6);
}

.t-footer-city-meta {
  display:         flex;
  align-items:     center;
  justify-content: space-between;
  gap:             8px;
}

.t-footer-city-meta strong {
  font-family: var(--t-font-sans);
  font-size:   0.9375rem;
  font-weight: 500;
  color:       var(--t-text-on-dark);
}

.t-footer-city-time {
  font-family:    var(--t-font-mono, var(--t-font-sans));
  font-size:      0.6875rem;
  font-weight:    500;
  letter-spacing: 0.05em;
  color:          var(--t-text-muted-dark);
  background:     rgba(245, 242, 238, 0.06);
  border:         1px solid rgba(245, 242, 238, 0.08);
  padding:        3px 8px;
  border-radius:  4px;
}

.t-footer-city-tz {
  font-family:    var(--t-font-sans);
  font-size:      0.6875rem;
  font-weight:    500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color:          var(--t-text-muted-dark);
}

.hhs-footer-mod .hhs-foot-break-line {
  border-top: 1px solid rgba(245, 242, 238, 0.08);
  margin:     32px 0 24px;
  width:      100% !important;
}

.hhs-footer-mod .hhs-foot-nav-base {
  align-items: center;
}

.hhs-footer-mod .hhs-foot-logo img {
  filter:    brightness(0) invert(1);
  max-width: 64px !important;
  margin-bottom: 0;
}

.hhs-footer-mod .hhs-foot-base-nav ul {
  display:    flex;
  gap:        24px;
  list-style: none;
  padding:    0;
  margin:     0;
}

.hhs-footer-mod .hhs-foot-base-nav a {
  font-family:    var(--t-font-sans) !important;
  font-size:      0.6875rem !important;
  font-weight:    500 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color:          var(--t-text-muted-dark) !important;
  text-decoration: none !important;
  transition:     color 220ms ease;
}

.hhs-footer-mod .hhs-foot-base-nav a:hover {
  color: var(--t-text-on-dark) !important;
}

.hhs-footer-mod .hhs-foot-copyright {
  font-family:    var(--t-font-sans) !important;
  font-size:      0.6875rem !important;
  font-weight:    500 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  color:          var(--t-text-muted-dark) !important;
  margin:         12px 0 0 !important;
}

.hhs-footer-mod .hhs-social-con {
  display:         flex;
  gap:             16px;
  justify-content: flex-end;
}

.hhs-footer-mod .hhs-social-con a {
  width:           32px;
  height:          32px;
  border-radius:   50%;
  background:      var(--t-dark-secondary);
  border:          1px solid rgba(245, 242, 238, 0.08);
  display:         flex;
  align-items:     center;
  justify-content: center;
  transition:      background 220ms ease, border-color 220ms ease;
}

.hhs-footer-mod .hhs-social-con a:hover {
  background:   var(--t-magenta);
  border-color: var(--t-magenta);
}

.hhs-footer-mod .hhs-social-con svg {
  width:  14px;
  height: 14px;
  fill:   var(--t-text-on-dark);
}

@media (max-width: 1024px) {
  .t-footer-cities {
    grid-template-columns: 1fr 1fr 1fr;
  }

  .hhs-footer-mod .hhs-foot-nav-cols .col-md-4 {
    margin-bottom: 24px;
  }
}

@media (max-width: 640px) {
  .hhs-footer-mod .container,
  .t-footer-extras {
    padding: 0 20px !important;
  }

  .t-footer-cities {
    grid-template-columns: 1fr;
  }

  .t-footer-cities::before {
    font-size: 5rem;
  }

  .hhs-footer-mod .hhs-foot-nav-base .col-sm-6 {
    width: 100%;
  }

  .hhs-footer-mod .hhs-social-con {
    justify-content: flex-start;
    margin-bottom:   24px;
  }
}

/* ============================================================
   SERVICES PAGE - HERO + NAV STRIP
   ============================================================ */

.t-services-hero {
  padding-top:    96px !important;
  padding-bottom: 64px !important;
  text-align:     left;
}

.t-services-hero .t-section-heading {
  font-size:  clamp(2.25rem, 4.5vw, 3.5rem) !important;
  margin:     0 0 24px !important;
  text-align: left !important;
}

.t-services-hero .t-section-intro {
  max-width:  520px;
  margin:     0 !important;
  text-align: left !important;
}
.t-services-nav {
  width:         100vw !important;
  position:      relative !important;
  left:          50% !important;
  right:         50% !important;
  margin-left:   -50vw !important;
  margin-right:  -50vw !important;
  background:    var(--t-cream-dark, #F2EDE6);
  border-top:    1px solid var(--t-border);
  border-bottom: 1px solid var(--t-border);
  padding:       12px 0;
}

.t-services-nav-inner {
  margin:          0 auto;
  padding:         0 32px;
  display:         flex;
  align-items:     center;
  justify-content: center;
  flex-wrap:       wrap;
  gap:             20px 24px;
}

.t-services-nav-label {
  font-family:    var(--t-font-sans);
  font-size:      0.6875rem;
  font-weight:    500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color:          var(--t-text-muted);
  display:        flex;
  align-items:    center;
  gap:            8px;
}

.t-services-nav-label::before {
  content:       '';
  display:       inline-block;
  width:         6px;
  height:        6px;
  border-radius: 50%;
  background:    var(--t-magenta);
}

.t-services-nav-link {
  display:         inline-flex;
  align-items:     center;
  gap:             8px;
  font-family:     var(--t-font-sans);
  font-size:       0.875rem;
  font-weight:     500;
  color:           var(--t-text-primary);
  text-decoration: none;
  white-space:     nowrap;
  position:        relative;
  transition:      color 220ms ease;
}

.t-services-nav-link:hover {
  color: var(--t-magenta);
}

.t-services-nav-num {
  font-family:    var(--t-font-mono, var(--t-font-sans));
  font-size:      0.75rem;
  font-weight:    500;
  color:          var(--t-magenta);
  letter-spacing: 0.02em;
}

.t-services-nav-link:not(:last-child)::after {
  content:     '·';
  margin-left: 24px;
  color:       var(--t-text-muted);
  opacity:     0.5;
  font-size:   1rem;
}

@media (max-width: 1100px) {
  .t-services-nav-inner {
    flex-wrap:       nowrap;
    overflow-x:      auto;
    justify-content: flex-start;
    padding:         0 20px;
    gap:             20px;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }

  .t-services-nav-inner::-webkit-scrollbar {
    display: none;
  }

  .t-services-nav-link,
  .t-services-nav-label {
    flex-shrink: 0;
  }

  .t-services-nav-link:not(:last-child)::after {
    margin-left: 20px;
  }
}
/* ============================================================
   SERVICES PAGE - SERVICE BLOCK
   ============================================================ */

.t-service-inner {
  max-width:    1460px;
  margin:       0 auto;
  padding:      0 40px;
  position:     relative;
}

.t-service-bignum {
  position:    absolute;
  top:         -50px;
  left:        -120px;
  font-family: var(--t-font-serif);
  font-size:   clamp(7rem, 12vw, 11rem);
  font-weight: 400;
  font-style:  italic;
  line-height: 1;
  color:       rgba(26, 26, 26, 0.03);
  pointer-events: none;
  user-select: none;
  z-index:     0;
}

.t-service-head {
  display:               grid;
  grid-template-columns: 1.1fr 1fr;
  gap:                   80px;
  align-items:           start;
  padding-left:          120px;
  margin-bottom:         56px;
  position:              relative;
  z-index:               1;
}

.t-service-eyebrow {
  font-family:    var(--t-font-sans);
  font-size:      0.6875rem;
  font-weight:    500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color:          var(--t-text-muted);
  display:        block;
  margin-bottom:  16px;
}

.t-service-title {
  font-family:    var(--t-font-serif);
  font-size:      clamp(2rem, 4vw, 3.25rem);
  font-weight:    400;
  font-style:     italic;
  line-height:    1.05;
  letter-spacing: -0.02em;
  color:          var(--t-text-primary);
  margin:         0;
}

.t-service-intro {
  font-family: var(--t-font-sans);
  font-size:   0.9375rem;
  line-height: 1.7;
  color:       var(--t-text-muted);
  margin:      0;
  padding-top: 12px;
}

.t-service-grid {
  display:               grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap:                   20px;
  margin-bottom:         32px;
  position:              relative;
  z-index:               1;
}

.t-service-card {
  padding: 24px 24px 28px !important;
}

.t-service-card-num {
  font-family:    var(--t-font-mono, var(--t-font-sans));
  font-size:      0.6875rem;
  font-weight:    500;
  color:          var(--t-magenta);
  letter-spacing: 0.04em;
  display:        block;
  margin-bottom:  16px;
}

.t-service-callout {
  display:        flex;
  align-items:    center;
  gap:            16px;
  flex-wrap:      wrap;
  padding:        16px 24px;
  border:         1px solid var(--t-magenta);
  border-radius:  8px;
  background:     transparent;
  margin-top:     8px;
}

.t-service-callout-label {
  font-family:    var(--t-font-sans);
  font-size:      0.6875rem;
  font-weight:    500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color:          var(--t-magenta);
  flex-shrink:    0;
}

.t-service-callout-text {
  font-family: var(--t-font-sans);
  font-size:   0.875rem;
  line-height: 1.5;
  color:       var(--t-text-primary);
}

@media (max-width: 1024px) {
  .t-service-head {
    grid-template-columns: 1fr;
    padding-left:          80px;
    gap:                   24px;
  }

  .t-service-grid {
    grid-template-columns: 1fr 1fr;
  }

  .t-service-bignum {
    font-size: 6rem;
    top:       -16px;
  }
}

@media (max-width: 640px) {
  .t-service {
    padding: 72px 0 56px;
  }

  .t-service-head {
    padding-left: 0;
  }

  .t-service-bignum {
    position: static;
    display:  block;
    margin-bottom: 16px;
  }

  .t-service-grid {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .t-service-callout {
    padding: 14px 18px;
  }
}
.t-service-grid--2col {
  grid-template-columns: 1fr 1fr;
}

.t-service-icon {
  width:           38px;
  height:          38px;
  border-radius:   8px;
  background:      var(--t-magenta-light);
  color:           var(--t-magenta);
  display:         flex;
  align-items:     center;
  justify-content: center;
  margin-top:      24px;
}

.t-service-icon svg {
  width:  18px;
  height: 18px;
}

@media (max-width: 768px) {
  .t-service-grid--2col {
    grid-template-columns: 1fr;
  }
}

.t-service-head--centered {
  display:        block !important;
  text-align:     center;
  padding-left:   0 !important;
  max-width:      720px;
  margin:         0 auto 56px !important;
}

.t-service-head--centered .t-service-eyebrow {
  text-align: center;
}

.t-service-head--centered .t-service-title {
  text-align: center;
  margin-bottom: 24px;
}

.t-service-intro--centered {
  text-align: center;
  margin: 0 auto !important;
  max-width: 600px;
}

.t-service-bignum--left {
  left: 12px;
  top:  -20px;
}

.t-service-grid--horizontal {
  max-width: 960px;
  margin-left: auto;
  margin-right: auto;
}

.t-service-card--horizontal {
  background:    rgba(233, 43, 109, 0.025) !important;
  border-color:  rgba(233, 43, 109, 0.12) !important;
  display:       grid !important;
  grid-template-columns: auto 1fr;
  gap:           20px;
  align-items:   start;
  padding:       22px 24px !important;
}

.t-service-card-numeral {
  font-family:  var(--t-font-serif);
  font-size:    1.625rem;
  font-weight:  400;
  font-style:   italic;
  line-height:  1;
  color:        var(--t-magenta);
  padding-top:  2px;
}

.t-service-card--horizontal .t-card-title {
  margin-bottom: 8px !important;
}

@media (max-width: 640px) {
  .t-service-card--horizontal {
    gap: 14px;
    padding: 18px 20px !important;
  }

  .t-service-card-numeral {
    font-size: 1.375rem;
  }
}


.t-service--dark {
  background: var(--t-dark);
  color:      var(--t-text-on-dark);
}

.t-service--dark .t-service-eyebrow,
.t-service--dark .t-service-intro {
  color: var(--t-text-muted-dark);
}

.t-service--dark .t-service-title {
  color: var(--t-text-on-dark);
}

.t-service-bignum--dark {
  color: rgba(245, 242, 238, 0.04);
}

.t-service-list {
  margin:        56px 0 32px;
  padding-left:  120px;
  border-top:    1px solid rgba(245, 242, 238, 0.08);
  position:      relative;
  z-index:       1;
}

.t-service-row {
  display:               grid;
  grid-template-columns: 60px 280px 1fr;
  gap:                   32px;
  align-items:           start;
  padding:               24px 0;
  border-bottom:         1px solid rgba(245, 242, 238, 0.08);
}

.t-service-row-num {
  font-family:    var(--t-font-mono, var(--t-font-sans));
  font-size:      0.75rem;
  font-weight:    500;
  color:          var(--t-magenta);
  letter-spacing: 0.04em;
  padding-top:    4px;
}

.t-service-row-title {
  font-family: var(--t-font-sans) !important;
  font-size:   1rem !important;
  font-weight: 500 !important;
  line-height: 1.4 !important;
  color:       var(--t-text-on-dark) !important;
  margin:      0 !important;
  padding-top: 2px;
}

.t-service-row-body {
  font-family: var(--t-font-sans);
  font-size:   0.875rem;
  line-height: 1.7;
  color:       var(--t-text-muted-dark);
  margin:      0;
  padding-top: 2px;
}

/* ── Callout dark variant ── */
.t-service-callout--dark {
  background: transparent;
}

.t-service-callout--dark .t-service-callout-text {
  color: var(--t-text-on-dark);
}

@media (max-width: 1024px) {
  .t-service-list {
    padding-left: 80px;
  }

  .t-service-row {
    grid-template-columns: 40px 1fr;
    gap: 16px;
  }

  .t-service-row-body {
    grid-column: 2;
  }

  .t-service-row-title {
    grid-column: 2;
  }
}

@media (max-width: 640px) {
  .t-service-list {
    padding-left: 0;
  }

  .t-service-row {
    grid-template-columns: 32px 1fr;
    padding: 20px 0;
  }
}
.t-service--dark .t-card,
.t-service--dark .t-service-card {
  background:    #2A2926 !important;
  border-color:  rgba(245, 242, 238, 0.06) !important;
}

.t-service--dark .t-card:hover,
.t-service--dark .t-service-card:hover {
  border-color: rgba(245, 242, 238, 0.18) !important;
}

.t-service--dark .t-card-title {
  color: var(--t-text-on-dark) !important;
}

.t-service--dark .t-card-body {
  color: var(--t-text-dark) !important;
}

/* ============================================================
   SERVICES PAGE - HOW WE ENAGAGE
   ============================================================ */

.t-engagements-header {
  display:               grid;
  grid-template-columns: 1.2fr 1fr;
  gap:                   80px;
  align-items:           start;
  margin-bottom:         56px;
}

.t-engagements-intro {
  font-family: var(--t-font-sans);
  font-size:   0.9375rem;
  line-height: 1.7;
  color:       var(--t-text-muted);
  margin:      0;
  padding-top: 24px;
  max-width:   320px;
}

.t-engagement-card {
  padding:  32px 32px 32px !important;
  display:  flex;
  flex-direction: column;
}

.t-engagement-card--featured {
  background:   var(--t-dark) !important;
  border-color: var(--t-dark) !important;
  color:        var(--t-text-on-dark);
}

.t-engagement-card--featured .t-engagement-eyebrow,
.t-engagement-card--featured .t-engagement-meta {
  color: var(--t-text-muted-dark);
}

.t-engagement-card--featured .t-engagement-title,
.t-engagement-card--featured .t-engagement-tags {
  color: var(--t-text-on-dark);
}

.t-engagement-card--featured .t-engagement-summary {
  color: var(--t-text-muted-dark);
}

.t-engagement-card--featured .t-engagement-divider {
  border-top-color: rgba(245, 242, 238, 0.12);
}

.t-engagement-card--featured .t-engagement-list li {
  color: var(--t-text-on-dark);
}

.t-engagement-card-top {
  display:         flex;
  align-items:     center;
  justify-content: space-between;
  gap:             12px;
  margin-bottom:   16px;
}

.t-engagement-badge {
  display:        inline-flex;
  align-items:    center;
  gap:            6px;
  padding:        4px 10px 4px 10px;
  background:     rgba(233, 43, 109, 0.18);
  border:         1px solid rgba(233, 43, 109, 0.4);
  border-radius:  100px;
  font-family:    var(--t-font-sans);
  font-size:      0.5rem;
  font-weight:    500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color:          var(--t-magenta);
}

.t-engagement-badge::before {
  content:       '';
  width:         5px;
  height:        5px;
  border-radius: 50%;
  background:    var(--t-magenta);
}

.t-engagement-eyebrow {
  font-family:    var(--t-font-sans);
  font-size:      0.5rem;
  font-weight:    500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color:          var(--t-text-muted);
  display:        inline-block;
  margin-bottom:  16px;
}

.t-engagement-card-top .t-engagement-eyebrow {
  margin-bottom: 0;
}

.t-engagement-title {
  font-family:    var(--t-font-serif);
  font-size:      2rem;
  font-weight:    400;
  font-style:     italic;
  line-height:    1.05;
  letter-spacing: -0.02em;
  color:          var(--t-text-primary);
  margin:         0 0 16px;
}

.t-engagement-summary {
  font-family: var(--t-font-sans);
  font-size:   0.8rem;
  line-height: 1.6;
  color:       var(--t-text-muted);
  margin:      0;
}

.t-engagement-divider {
  border-top: 1px solid var(--t-border);
  margin:     24px 0 20px;
}

.t-engagement-meta {
  font-family:    var(--t-font-sans);
  font-size:      0.6rem;
  font-weight:    500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color:          var(--t-text-muted);
  display:        block;
  margin-bottom:  10px;
}

.t-engagement-tags {
  font-family: var(--t-font-sans);
  font-size:   0.9rem;
  font-weight: 500;
  color:       var(--t-text-primary);
  margin:      0 0 24px;
  line-height: 1.5;
}

.t-engagement-list {
  list-style: none;
  padding:    0;
  margin:     0 0 28px;
  display:    flex;
  flex-direction: column;
  gap:        10px;
  flex-grow:  1;
}

.t-engagement-list li {
  font-family:  var(--t-font-sans);
  font-size:    0.875rem;
  line-height:  1.5;
  color:        var(--t-text-primary);
  padding-left: 22px;
  position:     relative;
}

.t-engagement-list li::before {
  content:     '+';
  position:    absolute;
  left:        0;
  top:         0;
  color:       var(--t-magenta);
  font-weight: 500;
}

/* ── Feature list ── */
.t-engagement-list,
ul.t-engagement-list {
  list-style: none !important;
  padding:    0 !important;
  margin:     0 0 28px !important;
  display:    flex;
  flex-direction: column;
  gap:        10px;
  flex-grow:  1;
}

.t-engagement-list li {
  font-family:  var(--t-font-sans) !important;
  font-size:    0.8rem !important;
  line-height:  1.5 !important;
  color:        var(--t-text-primary) !important;
  padding-left: 22px !important;
  position:     relative !important;
  list-style:   none !important;
  margin:       0 !important;
}

.t-engagement-list li::before {
  content:       '' !important;
  position:      absolute !important;
  left:          0 !important;
  top:           8px !important;
  width:         6px !important;
  height:        6px !important;
  border-radius: 50% !important;
  background:    var(--t-magenta) !important;
  display:       block !important;
}

.t-engagement-card--featured .t-engagement-list li {
  color: var(--t-text-on-dark) !important;
}

.t-engagement-cta {
  font-family:     var(--t-font-sans);
  font-size:       0.8rem;
  font-weight:     500;
  color:           var(--t-text-primary);
  text-decoration: none;
  margin-top:      auto;
  padding-top:     12px;
  transition:      color 220ms ease;
}

.t-engagement-cta:hover {
  color: var(--t-magenta);
}

.t-engagement-cta--featured {
  color: var(--t-magenta) !important;
}

.t-engagement-cta--featured:hover {
  color: #FF5577 !important;
}

@media (max-width: 1024px) {
  .t-engagements-header {
    grid-template-columns: 1fr;
    gap: 24px;
  }

  .t-engagements-intro {
    padding-top: 0;
    max-width: none;
  }
}

@media (max-width: 640px) {
  .t-engagement-card {
    padding: 24px 20px !important;
  }

  .t-engagement-title {
    font-size: 1.75rem;
  }
}
/* ============================================================
   CASE STUDIES LISTING PAGE
   ============================================================ */
.t-case-studies-hero {
  padding-top:    96px !important;
  padding-bottom: 64px !important;
  text-align:     center;
}

.t-case-studies-hero .t-section-header {
  max-width: 720px;
  margin:    0 auto;
}

.t-case-studies-hero .t-section-heading,
.t-case-studies-hero .t-section-label,
.t-case-studies-hero .t-section-intro {
  text-align: center !important;
}

.t-case-studies-hero .t-section-intro {
  max-width: 540px;
  margin:    24px auto 0 !important;
}

.t-case-studies-nav {
  background:    var(--t-cream-dark);
  border-top:    1px solid var(--t-border);
  border-bottom: 1px solid var(--t-border);
  padding:       16px 0;
  width:         100%;
}

.t-case-studies-nav-inner {
  max-width:       1160px;
  margin:          0 auto;
  padding:         0 40px;
  display:         flex;
  align-items:     center;
  justify-content: center;
  flex-wrap:       wrap;
  gap:             12px;
}

.t-case-studies-nav-link {
  display:         inline-flex;
  align-items:     center;
  padding:         8px 18px;
  font-family:     var(--t-font-sans);
  font-size:       0.875rem;
  font-weight:     500;
  color:           var(--t-text-primary);
  text-decoration: none;
  border-radius:   100px;
  background:      transparent;
  transition:      background 220ms ease, color 220ms ease;
  white-space:     nowrap;
}

.t-case-studies-nav-link:hover {
  background: rgba(233, 43, 109, 0.06);
  color:      var(--t-magenta);
}

.t-case-studies-nav-link--active {
  background: var(--t-magenta) !important;
  color:      var(--t-white) !important;
}

.t-case-studies-grid {
  padding-top:    80px !important;
  padding-bottom: 80px !important;
}

.t-case-study-card {
  background:    var(--t-white);
  border:        1px solid var(--t-border);
  border-radius: 12px;
  overflow:      hidden;
  display:       flex;
  flex-direction: column;
  transition:    transform 220ms ease, box-shadow 220ms ease;
}

.t-case-study-card:hover {
  transform:  translateY(-2px);
  box-shadow: 0 8px 24px rgba(28, 27, 25, 0.08);
}

.t-case-study-card-header {
  height:     180px;
  background: linear-gradient(135deg, 
    #F8B4A0 0%, 
    #F4BCD2 25%, 
    #E8729A 50%, 
    #CF6060 75%, 
    #E8622A 100%
  );
  position: relative;
}

.t-case-study-card-header::after {
  content:    '';
  position:   absolute;
  inset:      0;
  background: linear-gradient(180deg, 
    transparent 0%, 
    rgba(250, 247, 244, 0.4) 100%
  );
}

.t-case-study-card-body {
  padding: 28px 28px 32px;
  flex-grow: 1;
  display: flex;
  flex-direction: column;
}

.t-case-study-tags {
  display:    flex;
  flex-wrap:  wrap;
  gap:        8px;
  margin-bottom: 16px;
}

.t-case-study-tag {
  font-family:    var(--t-font-sans);
  font-size:      0.6875rem;
  font-weight:    500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color:          var(--t-magenta);
  padding:        4px 10px;
  background:     var(--t-magenta-light);
  border-radius:  4px;
}

.t-case-study-card-title {
  font-family:    var(--t-font-serif);
  font-size:      1.75rem;
  font-weight:    400;
  font-style:     italic;
  line-height:    1.1;
  letter-spacing: -0.02em;
  color:          var(--t-text-primary);
  margin:         0 0 16px;
}

.t-case-study-outcome {
  font-family: var(--t-font-sans);
  font-size:   1rem;
  font-weight: 500;
  line-height: 1.5;
  color:       var(--t-text-primary);
  margin:      0 0 12px;
}

.t-case-study-description {
  font-family: var(--t-font-sans);
  font-size:   0.875rem;
  line-height: 1.65;
  color:       var(--t-text-muted);
  margin:      0 0 24px;
  flex-grow:   1;
}

.t-case-study-cta {
  font-family:     var(--t-font-sans);
  font-size:       0.875rem;
  font-weight:     500;
  color:           var(--t-magenta);
  text-decoration: none;
  display:         inline-flex;
  align-items:     center;
  gap:             4px;
  margin-top:      auto;
  transition:      gap 220ms ease;
}

.t-case-study-cta:hover {
  gap: 8px;
}

.t-pagination {
  display:         flex;
  align-items:     center;
  justify-content: center;
  gap:             32px;
  margin-top:      56px;
  padding-top:     40px;
  border-top:      1px solid var(--t-border);
}

.t-pagination-link {
  font-family:     var(--t-font-sans);
  font-size:       0.875rem;
  font-weight:     500;
  color:           var(--t-text-primary);
  text-decoration: none;
  padding:         10px 20px;
  border:          1px solid var(--t-border);
  border-radius:   100px;
  transition:      all 220ms ease;
}

.t-pagination-link:hover {
  background:   var(--t-magenta);
  border-color: var(--t-magenta);
  color:        var(--t-white);
}

.t-pagination-info {
  font-family: var(--t-font-sans);
  font-size:   0.875rem;
  color:       var(--t-text-muted);
}

@media (max-width: 900px) {
  .t-case-studies-nav-inner {
    flex-wrap:      nowrap;
    overflow-x:     auto;
    justify-content: flex-start;
    padding:        0 20px;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }

  .t-case-studies-nav-inner::-webkit-scrollbar {
    display: none;
  }

  .t-case-studies-nav-link {
    flex-shrink: 0;
  }
}

@media (max-width: 640px) {
  .t-case-study-card-header {
    height: 140px;
  }

  .t-case-study-card-title {
    font-size: 1.5rem;
  }
}

/* CONTACT US PAGE */
.t-eyebrow {
  display: block;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: #9A9793;
  margin-bottom: 1.25rem;
}

.t-hero-heading {
  font-style: italic;
  font-weight: 500;
  font-size: clamp(2.4rem, 5.5vw, 4.2rem);
  line-height: 1.1;
  color: #1A1918;
  letter-spacing: -.01em;
  margin-bottom: 1.25rem;
}

.t-hero-sub {
  font-size: 15px;
  color: #4A4946;
  max-width: 420px;
  line-height: 1.65;
  margin: 0;
}
.rw-wrap {
  padding-top: var(--t-section-pad-y-sm);
}

.rw-label {
  font-family: var(--t-font-sans);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--t-text-light);
  margin-bottom: 1rem;
}

.rw-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border: 1px solid var(--t-border);
  border-radius: var(--t-radius-lg);
  overflow: hidden;
    background-color: var(--t-cream);
}

.rw-card {
  padding: 1.25rem 1.5rem;
  border-right: 1px solid var(--t-border);
}
.rw-card:last-child { border-right: none; }

.rw-card-title {
  font-family: var(--t-font-sans);
  font-size: var(--t-text-sm);
  font-weight: 500;
  color: var(--t-text-primary);
  line-height: var(--t-leading-snug);
  margin-bottom: .4rem;
}

.rw-card-meta {
  font-family: var(--t-font-sans);
  font-size: var(--t-text-xs);
  color: var(--t-text-light);
  margin: 0;
}

.rw-note {
  font-family: var(--t-font-sans);
  font-size: var(--t-text-sm);
  color: var(--t-text-light);
  text-align: center;
  margin: 0;
  padding: 1.5rem 0;
  border-top: 1px solid var(--t-border);
  margin-top: 2rem;
}

@media (max-width: 768px) {
  .rw-grid { grid-template-columns: repeat(2, 1fr); }
  .rw-card:nth-child(2) { border-right: none; }
  .rw-card:nth-child(1),
  .rw-card:nth-child(2) { border-bottom: 1px solid var(--t-border); }
}

@media (max-width: 480px) {
  .rw-grid { grid-template-columns: 1fr; }
  .rw-card { border-right: none; border-bottom: 1px solid var(--t-border); }
  .rw-card:last-child { border-bottom: none; }
}

/* Contact us form */
.form-section-wrap {
  background: var(--t-cream);
  padding: var(--t-section-pad-y) var(--t-container-pad);
}

.fs-author {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1.5rem 2rem;
  border: 1px solid var(--t-border);
  border-radius: var(--t-radius-lg) var(--t-radius-lg) 0 0;
  border-bottom: none;
}
.fs-avatar {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: var(--t-coral);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--t-font-sans);
  font-weight: 500;
  font-size: 15px;
  flex-shrink: 0;
}
.fs-author-name {
  font-family: var(--t-font-sans);
  font-weight: 500;
  font-size: var(--t-text-sm);
  color: var(--t-text-primary);
  margin: 0 0 .2rem;
}
.fs-author-note {
  font-family: var(--t-font-sans);
  font-size: var(--t-text-xs);
  color: var(--t-text-muted);
  margin: 0;
}

.hs-form-private {
  border: 1px solid var(--t-border);
  border-radius: 0 0 var(--t-radius-lg) var(--t-radius-lg);
  padding: 2rem 2rem 2.5rem;
}

.hs-form-private .form-columns-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}
.hs-form-private .form-columns-1 {
  display: grid;
  grid-template-columns: 1fr;
}

.hs-form-private .hs-form-field {
  margin-bottom: 1rem;
}

.hs-form-private label {
  font-family: var(--t-font-sans);
  font-size: var(--t-text-xs);
  font-weight: 500;
  color: var(--t-text-muted);
  letter-spacing: .02em;
  margin-bottom: .4rem;
  display: block;
}

.hs-form-private input[type="text"],
.hs-form-private input[type="email"],
.hs-form-private input[type="tel"],
.hs-input,
.hs-form-private textarea {
  width: 100%;
  background: var(--t-cream);
  border: 1px solid var(--t-border);
  border-radius: var(--t-radius-md);
  padding: .65rem .9rem;
  font-family: var(--t-font-sans);
  font-size: var(--t-text-sm);
  color: var(--t-text-primary);
  transition: border-color var(--t-duration) var(--t-ease),
              background var(--t-duration) var(--t-ease);
  outline: none;
  box-shadow: none;
  -webkit-appearance: none;
}
.hs-form-private input[type="text"]:focus,
.hs-form-private input[type="email"]:focus,
.hs-form-private textarea:focus {
  border-color: var(--t-border-strong);
  background: var(--t-white);
}
.hs-form-private input::placeholder,
.hs-form-private textarea::placeholder {
  color: var(--t-text-light);
}
.hs-form-private textarea {
  resize: vertical;
  min-height: 110px;
}

.hs-form-private .inputs-list {
  display: flex;
  flex-wrap: wrap;
  gap: .4rem;
  list-style: none;
  padding: 0;
  margin: 0;
}
.hs-form-private .inputs-list li {
  margin: 0;
}
.hs-form-private .inputs-list input[type="checkbox"],
.hs-form-private .inputs-list input[type="radio"] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
  pointer-events: none;
}
.hs-form-private .inputs-list label {
  font-family: var(--t-font-sans);
  font-size: var(--t-text-xs);
  font-weight: 400;
  color: var(--t-text-muted);
  background: var(--t-cream);
  border: 1px solid var(--t-border);
  border-radius: var(--t-radius-pill);
  padding: .3rem .9rem;
  cursor: pointer;
  transition: border-color var(--t-duration) var(--t-ease),
              background var(--t-duration) var(--t-ease),
              color var(--t-duration) var(--t-ease);
  display: inline-block;
  margin: 0;
  letter-spacing: 0;
}
.hs-form-private .inputs-list label:hover {
  border-color: var(--t-border-strong);
  background: var(--t-white);
}

.hs-form-private .inputs-list input[type="checkbox"]:checked + label,
.hs-form-private .inputs-list input[type="radio"]:checked + label {
  background: var(--t-text-primary);
  color: var(--t-white);
  border-color: var(--t-text-primary);
}

.hs-form-private .hs-button {
  display: block;
  width: 100%;
  background: -webkit-linear-gradient(45deg, rgba(229, 31, 111, 1.0) 0%, rgba(226, 73, 48, 1.0) 100%);
  color: #fff;
  border: none;
  border-radius: var(--t-radius-md);
  padding: .9rem .1rem;
  font-family: var(--t-font-sans);
  font-size: var(--t-text-sm);
  font-weight: 500;
  cursor: pointer;
  letter-spacing: .02em;
  margin-top: 1.5rem;
  transition: background var(--t-duration) var(--t-ease),
              transform var(--t-duration) var(--t-ease);
}
.hs-form-private .hs-button:hover {
  background: var(--t-coral-hover);
}
.hs-form-private .hs-button:active {
  transform: scale(.99);
}

.hs-form-private .hs-error-msgs {
  list-style: none;
  padding: 0;
  margin: .3rem 0 0;
}
.hs-form-private .hs-error-msgs label {
  font-size: var(--t-text-xs);
  color: var(--t-coral);
  font-weight: 400;
  margin: 0;
}

/*SIDEBAR*/
.fs-sidebar {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  position: sticky;
  top: 100px;
}

.fs-card {
  background: #FBF8F3 !important;
  border: 1px solid var(--t-border);
  border-radius: var(--t-radius-lg);
  padding: 1.75rem;
}

.fs-card-label {
  display: block;
  font-family: var(--t-font-sans);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--t-text-light);
  margin-bottom: 1rem;
}

.fs-steps {
  list-style: none;
  padding: 0;
  margin: 0;
}
.fs-steps li {
  display: flex;
  gap: .75rem;
  padding: .75rem 0;
  border-bottom: 1px solid var(--t-border);
  font-family: var(--t-font-sans);
  font-size: var(--t-text-sm);
  color: var(--t-text-muted);
  line-height: var(--t-leading-normal);
}
.fs-steps li:first-child { padding-top: 0; }
.fs-steps li:last-child { border-bottom: none; padding-bottom: 0; }

.fs-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--t-coral);
  flex-shrink: 0;
  margin-top: .45rem;
}

.fs-step-title {
  display: block;
  font-weight: 500;
  color: var(--t-text-primary);
  margin-bottom: .2rem;
}

.fs-card-text {
  font-family: var(--t-font-sans);
  font-size: var(--t-text-sm);
  color: var(--t-text-muted);
  line-height: var(--t-leading-relaxed);
  margin: 0;
}

.fs-commit-quote {
  font-family: var(--t-font-serif);
  font-style: italic;
  font-size: var(--t-text-xl);
  line-height: var(--t-leading-snug);
  color: var(--t-text-primary);
  margin-bottom: .85rem;
}

.fs-status {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  font-family: var(--t-font-sans);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--t-magenta);
}
.fs-status-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--t-coral);
  animation: fs-pulse 2s ease-in-out infinite;
}
@keyframes fs-pulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: .3; }
}

@media (max-width: 960px) {
  .fs-sidebar { position: static; }
}
@media (max-width: 600px) {
  .hs-form-private .form-columns-2 {
    grid-template-columns: 1fr;
  }
  .fs-author { padding: 1.25rem; }
  .hs-form-private { padding: 1.25rem; }
}

/* BOOK A CONSULT PAGE */
#hs_cos_wrapper_dnd_area-module-2 .clean-base {
 background: linear-gradient(170deg, 
    #FBEDE0 0%, 
    #F7D9DF 45%, 
    #F0C9D6 75%, 
    #EEDDE8 100%
  );
}
.bc-hero{
    text-align: center;
}
.bc-eyebrow {
  font-family: var(--t-font-sans);
  font-size: var(--t-text-xs);
  font-weight: 500;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--t-text-muted);
  margin-bottom: 1.25rem;
  display: block;
    text-align: center;
}

.bc-hero-heading {
  font-family: var(--t-font-serif);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(2.8rem, 6vw, 5rem);
  line-height: 1.1;
  color: var(--t-text-primary);
  margin-bottom: 1.5rem;
}

.bc-hero-sub {
  font-family: var(--t-font-sans);
  font-size: var(--t-text-base);
  color: var(--t-text-muted);
  max-width: 480px;
    margin-left: 450px;
  line-height: var(--t-leading-relaxed);
  margin-bottom: 2rem;
}

.bc-badges {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  flex-wrap: wrap;
  justify-content: center;
}

.bc-badge {
  font-family: var(--t-font-sans);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--t-text-muted);
}
.bc-badge + .bc-badge {
  padding-left: 1.5rem;
  border-left: 1px solid var(--t-border-strong);
}
.bc-cover-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: .65rem;
}

.bc-cover-list li {
  display: flex;
  align-items: flex-start;
  gap: .75rem;
  font-family: var(--t-font-sans);
  font-size: var(--t-text-sm);
  color: var(--t-text-muted);
  line-height: var(--t-leading-normal);
}

.bc-eyebrow {
  display: block;
  font-family: var(--t-font-sans);
  font-size: var(--t-text-xs);
  font-weight: 500;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--t-text-light);
  margin-bottom: 1.25rem;
}

.bc-who-list {
  font-family: var(--t-font-serif);
  font-style: italic;
  font-size: clamp(1.25rem, 2.5vw, 1.55rem);
  color: var(--t-text-primary);
  line-height: var(--t-leading-snug);
  margin-bottom: 1rem;
}

.bc-who-sub {
  font-family: var(--t-font-sans);
  font-size: var(--t-text-sm);
  color: var(--t-text-muted);
  max-width: 480px;
  margin: 0 auto;
  line-height: var(--t-leading-relaxed);
}
#hs_cos_wrapper_module_17788132551755,
#hs_cos_wrapper_module_17788132551755 .hhs-accordion-mod {
    background-color: #fff !important;
}
#hs_cos_wrapper_module_17764010691376 .hhs-rich-text.c1 span {
    text-align: center;
}