/*
 * Douglas Restorations layout, type, and component classes for GenerateBlocks.
 *
 * Apply these in Advanced -> Additional CSS class(es). GenerateBlocks owns the
 * markup; this stylesheet owns the tokenized presentation.
 */

body {
  background: var(--dr-color-cream);
  color: var(--dr-color-text);
  font-family: var(--dr-font-body);
}

/* GeneratePress and site chrome. */
/*
.site-header,
#primary main.site-main article .inside-article,
.site-footer footer.site-info,
body header nav.main-navigation {
  background-color: unset;
}

.dr-site-header {
  background: var(--dr-bg);
  border-bottom: 1px solid rgba(23, 36, 58, 0.08);
  position: relative;
  z-index: 50;
}

.dr-site-header__inner {
  align-items: center;
  box-sizing: border-box;
  display: flex;
  justify-content: space-between;
  margin-inline: auto;
  min-height: 92px;
  padding-inline: 0;
  width: min(100%, var(--dr-container));
}

.dr-site-header__nav a,
.dr-site-header__nav .gb-navigation__menu a,
.dr-site-header__nav .gb-menu-link {
  background: transparent;
  border: 0;
  color: var(--dr-color-text);
  font-family: var(--dr-font-body);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.2em;
  line-height: 1;
  min-block-size: auto;
  padding: 0;
  text-decoration: none;
  text-transform: uppercase;
}

.dr-site-header__nav a:hover,
.dr-site-header__nav a:focus-visible,
.dr-site-header__nav .gb-menu-link:hover,
.dr-site-header__nav .gb-menu-link:focus-visible {
  color: var(--dr-color-burgundy);
}

a {
  color: var(--dr-color-burgundy);
  text-underline-offset: 0.18em;
}

a:hover,
a:focus-visible {
  color: var(--dr-accent-dark);
}*/

/* Layout classes. 
.dr-container {
  box-sizing: border-box;
  inline-size: 100%;
  margin-inline: auto;
  max-inline-size: var(--dr-container);
  padding-inline: var(--dr-gutter);
}

.dr-container--wide {
  max-inline-size: var(--dr-container-wide);
}

.dr-section {
  box-sizing: border-box;
  padding-block: var(--dr-section-lg);
}

.dr-section--small {
  padding-block: var(--dr-section-md);
}

.dr-section--xl {
  padding-block: var(--dr-section-xl);
}

.dr-section--cream,
.dr-section--light {
  background: var(--dr-color-cream);
  color: var(--dr-color-text);
}

.dr-section--paper,
.dr-section--surface {
  background: var(--dr-color-paper);
  color: var(--dr-color-text);
}

.dr-section--navy,
.dr-section--dark {
  background: var(--dr-color-navy);
  color: var(--dr-color-white);
}

.dr-section--navy-deep {
  background: var(--dr-color-navy-deep);
  color: var(--dr-color-white);
}

.dr-section--burgundy,
.dr-section--accent {
  background: var(--dr-color-burgundy);
  color: var(--dr-color-white);
}

.dr-grid-2,
.dr-grid-3,
.dr-grid-4,
.dr-grid-auto {
  display: grid;
  gap: var(--dr-gap-lg);
}

.dr-grid-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.dr-grid-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.dr-grid-4 {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.dr-grid-auto {
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 260px), 1fr));
}

.dr-stack-sm,
.dr-stack-md,
.dr-stack-lg {
  display: flex;
  flex-direction: column;
}

.dr-stack-sm {
  gap: var(--dr-gap-sm);
}

.dr-stack-md {
  gap: var(--dr-gap-md);
}

.dr-stack-lg {
  gap: var(--dr-gap-lg);
}*/

/* Type classes. 
.dr-heading,
.dr-heading-xl,
.dr-heading-lg,
.dr-heading-md,
.dr-serif {
  font-family: var(--dr-font-display);
  font-weight: 400;
  letter-spacing: -0.025em;
  line-height: 1.04;
  margin-block: 0;
}

.dr-heading-xl,
.dr-heading--hero {
  font-size: var(--dr-hero-title);
  letter-spacing: -0.038em;
  line-height: 0.98;
}

.dr-heading-lg,
.dr-heading--section {
  font-size: var(--dr-section-title);
}

.dr-heading-md,
.dr-card-title {
  font-size: var(--dr-card-title);
  letter-spacing: -0.015em;
}

.dr-heading em,
.dr-heading-xl em,
.dr-heading-lg em,
.dr-heading-md em,
.dr-italic {
  font-family: var(--dr-font-display);
  font-style: italic;
}

.dr-eyebrow,
.dr-meta {
  font-family: var(--dr-font-body);
  font-size: var(--dr-eyebrow-size);
  font-weight: 700;
  letter-spacing: var(--dr-tracking-label);
  line-height: 1.45;
  text-transform: uppercase;
}

.dr-eyebrow {
  color: var(--dr-color-burgundy);
}

.dr-meta {
  color: var(--dr-color-muted);
}

.dr-lede {
  color: var(--dr-color-text);
  font-family: var(--dr-font-display);
  font-size: clamp(22px, 2.5vw, 34px);
  font-weight: 400;
  letter-spacing: -0.015em;
  line-height: 1.35;
}

.dr-body,
.dr-copy {
  color: var(--dr-color-muted);
  font-family: var(--dr-font-body);
  font-size: clamp(16px, 1.15vw, 18px);
  line-height: 1.85;
}

.dr-section--navy .dr-body,
.dr-section--navy .dr-copy,
.dr-section--dark .dr-body,
.dr-section--dark .dr-copy,
.dr-section--burgundy .dr-body,
.dr-section--accent .dr-copy,
.dr-section--accent .dr-body {
  color: rgba(255, 255, 255, 0.74);
}

.dr-section--navy .dr-meta,
.dr-section--dark .dr-meta,
.dr-section--burgundy .dr-meta,
.dr-section--accent .dr-meta,
.dr-section--burgundy .dr-eyebrow,
.dr-section--accent .dr-eyebrow {
  color: rgba(255, 255, 255, 0.78);
}

.dr-rule {
  background: var(--dr-color-burgundy);
  display: block;
  height: 1px;
  inline-size: 64px;
}*/

/* Component classes. 
.dr-nav-label,
.dr-button,
.gb-button.dr-button,
.wp-block-button__link.dr-button,
.dr-site-header__nav .gb-menu-link {
  font-family: var(--dr-sans);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.2em;
  line-height: 1;
  text-transform: uppercase;
}

.dr-button,
.gb-button.dr-button,
.wp-block-button__link.dr-button {
  align-items: center;
  background: var(--dr-color-burgundy);
  border: 1px solid var(--dr-color-burgundy);
  border-radius: 0;
  color: var(--dr-color-white);
  display: inline-flex;
  font-family: var(--dr-font-body);
  font-size: 12px;
  font-weight: 700;
  justify-content: center;
  letter-spacing: 0.2em;
  line-height: 1;
  min-block-size: 50px;
  padding: 17px 30px;
  text-decoration: none;
  text-transform: uppercase;
  transition: background-color 180ms ease, border-color 180ms ease,
    color 180ms ease;
}

.dr-button:hover,
.dr-button:focus-visible,
.gb-button.dr-button:hover,
.gb-button.dr-button:focus-visible,
.wp-block-button__link.dr-button:hover,
.wp-block-button__link.dr-button:focus-visible {
  background: var(--dr-color-navy);
  border-color: var(--dr-color-navy);
  color: var(--dr-color-white);
}

.dr-button--light,
.gb-button.dr-button--light,
.wp-block-button__link.dr-button--light {
  background: var(--dr-color-white);
  border-color: var(--dr-color-white);
  color: var(--dr-color-navy);
}

.dr-button--light:hover,
.dr-button--light:focus-visible,
.gb-button.dr-button--light:hover,
.gb-button.dr-button--light:focus-visible,
.wp-block-button__link.dr-button--light:hover,
.wp-block-button__link.dr-button--light:focus-visible {
  background: transparent;
  border-color: var(--dr-color-white);
  color: var(--dr-color-white);
}

.dr-button--outline,
.gb-button.dr-button--outline,
.wp-block-button__link.dr-button--outline {
  background: transparent;
  border-color: currentColor;
  color: var(--dr-color-burgundy);
}

.dr-section--navy .dr-button--outline,
.dr-section--dark .dr-button--outline,
.dr-section--burgundy .dr-button--outline,
.dr-section--accent .dr-button--outline {
  color: var(--dr-color-white);
}

.dr-link-cta {
  color: var(--dr-color-burgundy);
  display: inline-flex;
  font-family: var(--dr-font-body);
  font-size: 12px;
  font-weight: 700;
  gap: 0.8em;
  letter-spacing: 0.2em;
  text-decoration: none;
  text-transform: uppercase;
}

.dr-link-cta::after {
  content: "\2192";
  line-height: 1;
  transition: transform 180ms ease;
}

.dr-link-cta:hover::after,
.dr-link-cta:focus-visible::after {
  transform: translateX(4px);
}

.dr-hero {
  align-items: end;
  background: var(--dr-color-navy-deep);
  color: var(--dr-color-white);
  display: grid;
  min-block-size: clamp(520px, 72vh, 820px);
  overflow: hidden;
  position: relative;
}

.dr-hero > * {
  position: relative;
  z-index: 2;
}

.dr-hero__overlay,
.dr-image-overlay {
  position: relative;
}

.dr-hero__overlay::after,
.dr-image-overlay::after {
  background: linear-gradient(
    90deg,
    rgba(4, 20, 39, 0.72),
    rgba(4, 20, 39, 0.28)
  );
  content: "";
  inset: 0;
  pointer-events: none;
  position: absolute;
  z-index: 1;
}

.dr-card,
.dr-card-bordered {
  background: var(--dr-color-paper);
  border: 1px solid var(--dr-border-red);
  box-sizing: border-box;
  color: var(--dr-color-text);
  padding: clamp(28px, 4vw, 48px);
}

.dr-card-bordered {
  background: transparent;
}

.dr-card-article {
  color: var(--dr-color-text);
  display: grid;
  gap: var(--dr-gap-sm);
}

.dr-card-article img,
.dr-photo-frame img,
.dr-image-collage img {
  display: block;
  inline-size: 100%;
  object-fit: cover;
}

.dr-card-article img {
  aspect-ratio: 4 / 3;
  filter: grayscale(1) contrast(0.98);
}

.dr-photo-frame {
  border: 1px solid var(--dr-border-red);
  box-shadow: var(--dr-shadow-soft);
  filter: grayscale(1) contrast(0.95);
}

.dr-image-collage {
  display: grid;
  grid-template-columns: 1fr 0.72fr;
  isolation: isolate;
}

.dr-image-collage > *:first-child {
  grid-column: 1 / 3;
  grid-row: 1;
}

.dr-image-collage > *:last-child {
  align-self: end;
  grid-column: 2 / 3;
  grid-row: 1;
  margin-block-end: calc(var(--dr-gap-md) * -1);
  margin-inline-start: calc(var(--dr-gap-md) * -1);
  position: relative;
  z-index: 2;
}

.dr-quote-panel {
  background: var(--dr-color-burgundy);
  color: var(--dr-color-white);
  display: grid;
  gap: var(--dr-gap-lg);
  grid-template-columns: minmax(0, 0.82fr) minmax(0, 1.18fr);
  padding: clamp(40px, 6vw, 86px);
}

.dr-quote-panel blockquote,
.dr-quote-panel .dr-quote {
  font-family: var(--dr-font-display);
  font-size: clamp(32px, 4.4vw, 64px);
  font-style: italic;
  line-height: 1.08;
  margin: 0;
}

.dr-icon-line {
  align-items: center;
  color: var(--dr-color-burgundy);
  display: inline-flex;
  gap: 14px;
}

.dr-icon-line::before {
  background: currentColor;
  content: "";
  display: inline-block;
  height: 1px;
  inline-size: 42px;
}

.dr-thumb-grid {
  display: grid;
  gap: clamp(10px, 1.4vw, 18px);
  grid-template-columns: repeat(6, minmax(0, 1fr));
}

.dr-thumb-grid img {
  aspect-ratio: 1;
  display: block;
  filter: grayscale(1) contrast(0.95);
  inline-size: 100%;
  object-fit: cover;
}

.dr-footer {
  background: var(--dr-color-navy-deep);
  color: var(--dr-color-white);
  padding-block: clamp(82px, 8vw, 128px) clamp(44px, 5vw, 72px);
}

.dr-footer__inner {
  display: grid;
  gap: clamp(56px, 8vw, 112px);
}

.dr-footer__primary {
  align-items: start;
  display: grid;
  gap: clamp(42px, 6vw, 96px);
  grid-template-columns: minmax(240px, 1.05fr) repeat(3, minmax(0, 0.75fr));
}

.dr-footer__brand {
  max-inline-size: 315px;
}

.dr-footer__logo {
  color: var(--dr-color-white);
  font-family: var(--dr-font-display);
  font-size: clamp(28px, 2.4vw, 38px);
  font-weight: 600;
  letter-spacing: 0.18em;
  line-height: 1;
  margin: 0;
  text-transform: uppercase;
}

.dr-footer__logo-subtitle {
  color: var(--dr-color-burgundy);
  display: block;
  font-family: var(--dr-font-body);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.32em;
  line-height: 1.4;
  margin-block-start: 8px;
  text-transform: uppercase;
}

.dr-footer__description {
  color: rgba(255, 255, 255, 0.62);
  font-family: var(--dr-font-body);
  font-size: 15px;
  line-height: 1.8;
  margin-block: 38px 0;
}

.dr-footer__column {
  display: grid;
  gap: 22px;
}

.dr-footer__links {
  display: grid;
  gap: 15px;
}

.dr-footer__link,
.dr-footer__contact-line,
.dr-footer__legal-link,
.dr-footer__copyright {
  color: rgba(255, 255, 255, 0.62);
  font-family: var(--dr-font-body);
  font-size: 15px;
  line-height: 1.55;
}

.dr-footer__contact-line {
  margin: 0;
}

.dr-footer__contact-line--bright {
  color: var(--dr-color-white);
}

.dr-footer__bottom {
  align-items: center;
  border-top: 1px solid rgba(255, 255, 255, 0.06);
  display: flex;
  gap: 28px;
  justify-content: space-between;
  padding-block-start: clamp(34px, 4vw, 56px);
}

.dr-footer__legal {
  display: flex;
  gap: clamp(24px, 4vw, 54px);
}

.dr-footer a {
  color: rgba(255, 255, 255, 0.82);
  text-decoration: none;
}

.dr-footer a:hover,
.dr-footer a:focus-visible {
  color: var(--dr-color-white);
}

.dr-footer .dr-eyebrow,
.dr-footer__label {
  color: var(--dr-color-burgundy);
}

.dr-footer__label {
  margin: 0;
}*/
