.gca-rates-widget,
.gca-rates-widget * {
  box-sizing: border-box;
}

.gca-rates-widget {
  --gca-ink: #070707;
  --gca-brown: #755629;
  --gca-gold: #bc8f3f;
  --gca-cream: #fdfaf5;
  --gca-muted: #635d57;
  clear: both;
  width: 100%;
  max-width: 1080px;
  margin: 32px auto;
  overflow: hidden;
  border: 1px solid rgba(117, 86, 41, .18);
  border-radius: 22px;
  background: #fff;
  box-shadow: 0 18px 52px rgba(7, 7, 7, .12);
  color: var(--gca-ink);
  font-family: inherit;
}

.gca-rates-widget__hero {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 220px;
  padding: 42px 50px;
  overflow: hidden;
  background: linear-gradient(125deg, #070707 0%, #21180c 48%, #755629 100%);
  color: #fff;
}

.gca-rates-widget__hero::after {
  position: absolute;
  right: -85px;
  bottom: -136px;
  width: 400px;
  height: 400px;
  border: 42px solid rgba(188, 143, 63, .20);
  border-radius: 50%;
  content: '';
}

.gca-rates-widget__hero-copy,
.gca-rates-widget__hero-mark {
  position: relative;
  z-index: 1;
}

.gca-rates-widget__hero-copy {
  max-width: 700px;
}

.gca-rates-widget__eyebrow,
.gca-rates-chart__eyebrow {
  display: inline-block;
  margin-bottom: 10px;
  color: #f4dba3;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .13em;
  text-transform: uppercase;
}

.gca-rates-widget__title {
  margin: 0;
  color: #fff;
  font-size: clamp(29px, 4vw, 46px);
  font-weight: 800;
  letter-spacing: -.045em;
  line-height: 1.06;
}

.gca-rates-widget__intro {
  max-width: 650px;
  margin: 14px 0 0;
  color: rgba(255, 255, 255, .85);
  font-size: 16px;
  line-height: 1.6;
}

.gca-rates-widget__hero-mark {
  display: grid;
  place-items: center;
  flex: 0 0 auto;
  width: 84px;
  height: 84px;
  margin-left: 25px;
  border: 1px solid rgba(255, 255, 255, .25);
  border-radius: 20px;
  background: rgba(255, 255, 255, .08);
  backdrop-filter: blur(4px);
}

.gca-rates-widget__hero-mark svg {
  width: 44px;
  height: 44px;
  fill: none;
  stroke: #f4dba3;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 2.3;
}

.gca-rates-widget__body {
  padding: 35px 42px 30px;
  background: linear-gradient(180deg, #fff 0%, var(--gca-cream) 100%);
}

.gca-rates-widget__asof {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  margin: 0 0 22px;
  color: var(--gca-brown);
  font-size: 13px;
  font-weight: 800;
  letter-spacing: .02em;
}

.gca-rates-widget__pulse {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: #4b7b3e;
  box-shadow: 0 0 0 4px rgba(75, 123, 62, .12);
}

.gca-rates-widget__cards {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 20px;
}

.gca-rate-card {
  position: relative;
  min-height: 243px;
  padding: 25px 26px 23px;
  overflow: hidden;
  border: 1px solid rgba(117, 86, 41, .17);
  border-radius: 16px;
  background: #fff;
  box-shadow: 0 10px 25px rgba(7, 7, 7, .055);
}

.gca-rate-card::before {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 5px;
  background: linear-gradient(90deg, var(--gca-gold), var(--gca-brown));
  content: '';
}

.gca-rate-card__topline {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.gca-rate-card__label {
  color: var(--gca-ink);
  font-size: 17px;
  font-weight: 800;
  line-height: 1.3;
}

.gca-rate-card__icon {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 10px;
  background: #f8f0e2;
  color: var(--gca-brown);
}

.gca-rate-card__icon svg {
  width: 19px;
  height: 19px;
  fill: none;
  stroke: currentColor;
  stroke-linecap: round;
  stroke-width: 2;
}

.gca-rate-card__rate {
  display: flex;
  align-items: flex-start;
  margin-top: 18px;
  color: var(--gca-brown);
  font-size: clamp(50px, 6vw, 68px);
  font-weight: 800;
  letter-spacing: -.07em;
  line-height: .88;
}

.gca-rate-card__rate sup {
  margin-top: 6px;
  margin-left: 4px;
  color: var(--gca-gold);
  font-size: .40em;
  letter-spacing: 0;
}

.gca-rate-card__rate--na {
  color: #707070;
  font-size: 38px;
  letter-spacing: -.04em;
}

.gca-rate-card__change {
  display: flex;
  align-items: center;
  gap: 5px;
  min-height: 22px;
  margin-top: 13px;
  color: #77716a;
  font-size: 12px;
  font-weight: 700;
}

.gca-rate-card__change--up { color: #9a4f2e; }
.gca-rate-card__change--down { color: #36713f; }
.gca-rate-card__change-arrow { font-size: 16px; line-height: 1; }

.gca-rate-card__note {
  margin: 14px 0 0;
  color: var(--gca-muted);
  font-size: 13px;
  line-height: 1.55;
}

.gca-rates-chart {
  margin-top: 26px;
  padding: 25px 26px 20px;
  border: 1px solid rgba(117, 86, 41, .15);
  border-radius: 16px;
  background: #fff;
}

.gca-rates-chart__heading {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 19px;
}

.gca-rates-chart__eyebrow {
  margin-bottom: 5px;
  color: var(--gca-brown);
  font-size: 10px;
}

.gca-rates-chart h3 {
  margin: 0;
  color: var(--gca-ink);
  font-size: 20px;
  font-weight: 800;
  letter-spacing: -.02em;
  line-height: 1.2;
}

.gca-rates-chart__legend {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 12px;
  color: #625a51;
  font-size: 12px;
  font-weight: 700;
}

.gca-rates-chart__legend span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.gca-rates-chart__dot {
  display: inline-block;
  width: 9px;
  height: 9px;
  border-radius: 50%;
}

.gca-rates-chart__dot--30 { background: var(--gca-gold); }
.gca-rates-chart__dot--15 { background: var(--gca-brown); }

.gca-rates-chart__helper {
  margin: -5px 0 15px;
  color: var(--gca-muted);
  font-size: 13px;
  line-height: 1.5;
}

.gca-rates-chart__canvas {
  position: relative;
  min-height: 270px;
  overflow: hidden;
}

.gca-rates-chart__canvas svg {
  display: block;
  width: 100%;
  height: auto;
  min-height: 250px;
}

.gca-rates-chart__loading {
  display: grid;
  min-height: 240px;
  place-items: center;
  color: #6f675e;
  font-size: 14px;
}

.gca-rates-chart__tooltip {
  position: absolute;
  z-index: 3;
  min-width: 168px;
  padding: 10px 12px;
  border: 1px solid rgba(117, 86, 41, .2);
  border-radius: 10px;
  background: rgba(7, 7, 7, .94);
  box-shadow: 0 8px 25px rgba(7, 7, 7, .18);
  color: #fff;
  font-size: 12px;
  line-height: 1.55;
  pointer-events: none;
  transform: translate(-50%, -112%);
}

.gca-rates-chart__tooltip strong {
  display: block;
  margin-bottom: 3px;
  color: #f4dba3;
  font-size: 11px;
}

.gca-rates-widget__cta-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  margin: 25px 0 0;
  padding: 19px 21px;
  border-radius: 14px;
  background: linear-gradient(120deg, #f6ebd8, #fdfaf5);
}

.gca-rates-widget__cta-row p {
  max-width: 630px;
  margin: 0;
  color: #504635;
  font-size: 14px;
  line-height: 1.55;
}

.gca-rates-widget__cta {
  display: inline-flex;
  flex: 0 0 auto;
  align-items: center;
  gap: 10px;
  padding: 13px 17px;
  border-radius: 9px;
  background: var(--gca-ink);
  color: #fff !important;
  font-size: 13px;
  font-weight: 800;
  line-height: 1.2;
  text-decoration: none !important;
  transition: transform .2s ease, background .2s ease;
}

.gca-rates-widget__cta:hover,
.gca-rates-widget__cta:focus {
  background: var(--gca-brown);
  color: #fff !important;
  transform: translateY(-1px);
}

.gca-rates-widget__cta span {
  font-size: 18px;
  line-height: .7;
}

.gca-rates-widget__disclaimer {
  margin: 23px 0 0;
  padding: 15px 18px;
  border-left: 4px solid var(--gca-gold);
  border-radius: 0 8px 8px 0;
  background: #f8f0e2;
  color: #57452a;
  font-size: 12px;
  line-height: 1.6;
}

.gca-rates-widget--compact {
  max-width: 740px;
}

.gca-rates-widget--compact .gca-rates-widget__body {
  padding: 24px;
}

.gca-rates-widget--compact .gca-rate-card {
  min-height: 202px;
}

.gca-rates-widget--compact .gca-rate-card__note {
  display: none;
}

.gca-rates-widget--error .gca-rates-widget__body {
  padding: 24px;
}

.gca-rates-error {
  display: flex;
  flex-direction: column;
  gap: 5px;
  padding: 20px;
  border: 1px solid rgba(188, 143, 63, .38);
  border-radius: 12px;
  background: #fff8e9;
  color: #57452a;
  font-size: 14px;
  line-height: 1.55;
}

.gca-rates-error strong {
  color: var(--gca-ink);
}

@media (max-width: 760px) {
  .gca-rates-widget { border-radius: 17px; }
  .gca-rates-widget__hero { min-height: auto; padding: 31px 25px; }
  .gca-rates-widget__hero-mark { display: none; }
  .gca-rates-widget__body { padding: 27px 22px 23px; }
  .gca-rates-widget__cards { grid-template-columns: 1fr; }
  .gca-rate-card { min-height: 218px; }
  .gca-rates-chart { padding: 21px 17px 16px; }
  .gca-rates-chart__heading { display: block; }
  .gca-rates-chart__legend { justify-content: flex-start; margin-top: 12px; }
  .gca-rates-chart__canvas { min-height: 230px; margin: 0 -5px; }
  .gca-rates-widget__cta-row { display: block; }
  .gca-rates-widget__cta { margin-top: 15px; }
}

@media (max-width: 440px) {
  .gca-rates-widget__title { font-size: 31px; }
  .gca-rate-card__rate { font-size: 56px; }
  .gca-rates-chart__legend { gap: 9px; font-size: 11px; }
}

/* Dedicated simple shortcode: [gca_mortgage_rate_simple] */
.gca-rates-simple,
.gca-rates-simple * {
  box-sizing: border-box;
}

.gca-rates-simple {
  --gca-simple-ink: #070707;
  --gca-simple-brown: #755629;
  --gca-simple-gold: #bc8f3f;
  width: 100%;
  max-width: 880px;
  margin: 28px auto;
  overflow: hidden;
  border: 1px solid rgba(117, 86, 41, .20);
  border-radius: 18px;
  background: #fff;
  box-shadow: 0 13px 34px rgba(7, 7, 7, .08);
  color: var(--gca-simple-ink);
  font-family: inherit;
}

.gca-rates-simple__header {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 22px;
  padding: 24px 28px 20px;
  border-bottom: 1px solid rgba(117, 86, 41, .13);
  background: linear-gradient(135deg, #fffdf9, #f7efe2);
}

.gca-rates-simple__eyebrow,
.gca-rates-sidebar__eyebrow {
  display: block;
  margin-bottom: 5px;
  color: var(--gca-simple-brown);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.gca-rates-simple h2 {
  margin: 0;
  color: var(--gca-simple-ink);
  font-size: 24px;
  font-weight: 800;
  letter-spacing: -.03em;
  line-height: 1.15;
}

.gca-rates-simple__date {
  flex: 0 0 auto;
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(255, 255, 255, .80);
  color: #665d52;
  font-size: 11px;
  font-weight: 700;
  white-space: nowrap;
}

.gca-rates-simple__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.gca-rates-simple__rate {
  min-height: 165px;
  padding: 23px 28px;
}

.gca-rates-simple__rate + .gca-rates-simple__rate {
  border-left: 1px solid rgba(117, 86, 41, .13);
}

.gca-rates-simple__label {
  display: block;
  color: #5d5449;
  font-size: 13px;
  font-weight: 800;
}

.gca-rates-simple__value {
  display: block;
  margin-top: 9px;
  color: var(--gca-simple-brown);
  font-size: clamp(42px, 6vw, 56px);
  font-weight: 800;
  letter-spacing: -.07em;
  line-height: .9;
}

.gca-rates-simple__value sup {
  margin-left: 3px;
  color: var(--gca-simple-gold);
  font-size: .38em;
  letter-spacing: 0;
  vertical-align: top;
}

.gca-rates-simple__value--na {
  color: #777;
  font-size: 30px;
  letter-spacing: -.03em;
}

.gca-rates-simple__change {
  display: block;
  min-height: 18px;
  margin-top: 13px;
  color: #71695f;
  font-size: 11px;
  font-weight: 700;
}

.gca-rates-simple__change--up { color: #9a4f2e; }
.gca-rates-simple__change--down { color: #36713f; }

.gca-rates-simple__note {
  margin: 0;
  padding: 13px 28px 15px;
  border-top: 1px solid rgba(117, 86, 41, .10);
  background: #fdfaf5;
  color: #71695f;
  font-size: 11px;
  line-height: 1.5;
}

/* Dedicated chart shortcode: [gca_mortgage_rate_chart] */
.gca-rates-chart-only {
  width: 100%;
  max-width: 1000px;
  margin: 28px auto;
}

.gca-rates-chart-only .gca-rates-chart {
  margin-top: 0;
  box-shadow: 0 13px 34px rgba(7, 7, 7, .07);
}

/* Dedicated compact sidebar shortcode: [gca_mortgage_rate_widget] */
.gca-rates-sidebar,
.gca-rates-sidebar * {
  box-sizing: border-box;
}

.gca-rates-sidebar {
  --gca-sidebar-ink: #070707;
  --gca-sidebar-brown: #755629;
  --gca-sidebar-gold: #bc8f3f;
  width: 100%;
  max-width: 420px;
  margin: 20px auto;
  overflow: hidden;
  border: 1px solid rgba(117, 86, 41, .20);
  border-radius: 15px;
  background: #fff;
  box-shadow: 0 10px 28px rgba(7, 7, 7, .08);
  color: var(--gca-sidebar-ink);
  font-family: inherit;
}

.gca-rates-sidebar__header {
  padding: 21px 21px 16px;
  background: linear-gradient(130deg, #070707, #422e10 72%, #755629);
  color: #fff;
}

.gca-rates-sidebar__eyebrow {
  color: #f4dba3;
}

.gca-rates-sidebar h3 {
  margin: 0;
  color: #fff;
  font-size: 22px;
  font-weight: 800;
  letter-spacing: -.03em;
  line-height: 1.15;
}

.gca-rates-sidebar__header p {
  margin: 7px 0 0;
  color: rgba(255, 255, 255, .74);
  font-size: 11px;
  line-height: 1.45;
}

.gca-rates-sidebar__rates {
  padding: 7px 18px;
}

.gca-rates-sidebar__row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 16px 3px;
}

.gca-rates-sidebar__row + .gca-rates-sidebar__row {
  border-top: 1px solid rgba(117, 86, 41, .13);
}

.gca-rates-sidebar__row > div {
  display: flex;
  min-width: 0;
  flex-direction: column;
  gap: 4px;
}

.gca-rates-sidebar__row span {
  color: #413b34;
  font-size: 13px;
  font-weight: 800;
}

.gca-rates-sidebar__change {
  color: #736b61;
  font-size: 10px;
  font-weight: 700;
}

.gca-rates-sidebar__change--up { color: #9a4f2e; }
.gca-rates-sidebar__change--down { color: #36713f; }

.gca-rates-sidebar__value {
  flex: 0 0 auto;
  color: var(--gca-sidebar-brown);
  font-size: 31px;
  font-weight: 800;
  letter-spacing: -.06em;
  line-height: 1;
}

.gca-rates-sidebar__value sup {
  margin-left: 2px;
  color: var(--gca-sidebar-gold);
  font-size: .42em;
  letter-spacing: 0;
  vertical-align: top;
}

.gca-rates-sidebar__value--na {
  color: #777;
  font-size: 22px;
  letter-spacing: -.03em;
}

.gca-rates-sidebar__cta {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  margin: 2px 18px 16px;
  padding: 12px 13px;
  border-radius: 8px;
  background: var(--gca-sidebar-ink);
  color: #fff !important;
  font-size: 12px;
  font-weight: 800;
  line-height: 1.2;
  text-align: center;
  text-decoration: none !important;
  transition: background .2s ease, transform .2s ease;
}

.gca-rates-sidebar__cta:hover,
.gca-rates-sidebar__cta:focus {
  background: var(--gca-sidebar-brown);
  color: #fff !important;
  transform: translateY(-1px);
}

.gca-rates-sidebar__cta span {
  font-size: 17px;
  line-height: .7;
}

.gca-rates-sidebar__disclaimer {
  margin: 0;
  padding: 10px 18px 13px;
  border-top: 1px solid rgba(117, 86, 41, .10);
  background: #fdfaf5;
  color: #766d62;
  font-size: 10px;
  line-height: 1.45;
  text-align: center;
}

.gca-rates-widget--error-sidebar {
  max-width: 420px;
  margin: 20px auto;
  border-radius: 15px;
}

.gca-rates-widget--error-sidebar .gca-rates-widget__body {
  padding: 16px;
}

@media (max-width: 620px) {
  .gca-rates-simple__header {
    display: block;
    padding: 21px 21px 17px;
  }

  .gca-rates-simple__date {
    display: inline-block;
    margin-top: 11px;
  }

  .gca-rates-simple__grid {
    grid-template-columns: 1fr;
  }

  .gca-rates-simple__rate {
    min-height: auto;
    padding: 20px 21px;
  }

  .gca-rates-simple__rate + .gca-rates-simple__rate {
    border-top: 1px solid rgba(117, 86, 41, .13);
    border-left: 0;
  }

  .gca-rates-simple__note {
    padding-right: 21px;
    padding-left: 21px;
  }
}

