/*
Theme Name: Duplex Projectos V10 Technical
Description: Standalone high-fidelity architectural theme.
Author: Vault Factory
Version: 10.2.6
*/

/* Fonts handled in theme functions for better performance */

/* 🎨 MASTER DESIGN TOKENS */
:root {
  --duplex-primary: #2c3e50;
  --duplex-text: #111111;
  --duplex-text-light: rgba(17, 17, 17, 0.4);
  --duplex-border: rgba(0, 0, 0, 0.05);
  --duplex-accent: #ff6b35;
  --font-heading: "Montserrat", sans-serif;
}

/* 🧭 NAVIGATION V18 (TECHNICAL FIDELITY) */
.duplex-nav-v8 .wp-block-navigation-item {
  margin-left: 40px !important;
}

.duplex-nav-v8 .wp-block-navigation-item__label {
  font-family: "Roboto Mono", monospace !important;
  font-size: 11px !important;
  font-weight: 500 !important;
  letter-spacing: 0.15em !important;
  text-transform: uppercase !important;
  color: rgba(0, 0, 0, 0.3) !important;
  transition: all 0.3s ease !important;
  position: relative;
  padding: 8px 0 !important;
  display: inline-block;
}

.duplex-nav-v8 .wp-block-navigation-item:hover .wp-block-navigation-item__label,
.duplex-nav-v8
  .wp-block-navigation-item.current-menu-item
  .wp-block-navigation-item__label {
  color: #111111 !important;
}

/* Cool Orange Underline Animation */
.duplex-nav-v8 .wp-block-navigation-item__label::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 0;
  height: 1px;
  background: var(--duplex-accent);
  transition: width 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.duplex-nav-v8
  .wp-block-navigation-item:hover
  .wp-block-navigation-item__label::after,
.duplex-nav-v8
  .wp-block-navigation-item.current-menu-item
  .wp-block-navigation-item__label::after {
  width: 100%;
}

.duplex-nav-v8 .wp-block-navigation__container {
  gap: 0 !important; /* Managed by item margin */
}

/* Header Visibility & Structure Fixes */
.duplex-header-v8 {
  position: relative !important;
  background: white !important; /* Ensure visibility */
  border-bottom: 1px solid rgba(0, 0, 0, 0.03);
}

.header-inner-container {
  max-width: 1800px;
  margin: 0 auto;
  padding: 22px clamp(22px, 4vw, 48px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
}

.branding-wrap {
  display: flex;
  align-items: center;
  gap: 18px;
  flex-shrink: 0;
}

.duplex-coords {
  font-family: "Roboto Mono", monospace;
  font-size: 10px;
  line-height: 1.4;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(0, 0, 0, 0.42);
}

.desktop-nav-container {
  margin-left: auto;
}

.duplex-nav-v8-list {
  list-style: none;
  display: flex;
  align-items: center;
  gap: 30px;
  margin: 0;
  padding: 0;
}

.duplex-nav-v8-list li {
  margin: 0;
  padding: 0;
}

.duplex-nav-v8-list a {
  font-family: "Roboto Mono", monospace;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: rgba(0, 0, 0, 0.42);
  text-decoration: none;
  padding: 8px 0;
  display: inline-block;
  position: relative;
  transition: color 0.25s ease;
}

.duplex-nav-v8-list a::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 0;
  height: 1px;
  background: var(--duplex-accent);
  transition: width 0.25s ease;
}

.duplex-nav-v8-list a:hover,
.duplex-nav-v8-list .current-menu-item > a,
.duplex-nav-v8-list .current_page_item > a {
  color: #111111;
}

.duplex-nav-v8-list a:hover::after,
.duplex-nav-v8-list .current-menu-item > a::after,
.duplex-nav-v8-list .current_page_item > a::after {
  width: 100%;
}

.mobile-menu-button {
  display: none;
  appearance: none;
  border: 0;
  background: transparent;
  padding: 0;
  width: 44px;
  height: 44px;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 6px;
  cursor: pointer;
  position: relative;
  z-index: 10001;
}

.mobile-menu-button .bar {
  width: 22px;
  height: 1.5px;
  background: #111111;
  display: block;
  transition: transform 0.25s ease, opacity 0.25s ease;
}

.mobile-menu-button.is-active .bar:first-child {
  transform: translateY(3.75px) rotate(45deg);
}

.mobile-menu-button.is-active .bar:last-child {
  transform: translateY(-3.75px) rotate(-45deg);
}

.mobile-menu-button.is-active {
  position: fixed;
  top: 18px;
  right: 18px;
  background: rgba(255, 255, 255, 0.96);
  border-radius: 999px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
}

.duplex-mobile-popup {
  position: fixed;
  inset: 0;
  background: rgba(255, 255, 255, 0.98);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.3s ease, visibility 0.3s ease;
  z-index: 9999;
}

.duplex-mobile-popup,
.duplex-mobile-popup.is-open {
  background-color: rgba(255, 255, 255, 0.98) !important;
}

.duplex-mobile-popup.is-open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.mobile-popup-inner {
  background-color: #ffffff !important;
  min-height: 100%;
  padding: 32px 24px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.mobile-popup-header,
.mobile-popup-footer {
  flex-shrink: 0;
}

.mobile-menu-content {
  flex: 1;
  display: flex;
  align-items: center;
}

.mobile-menu-links {
  list-style: none;
  margin: 0;
  padding: 0;
  width: 100%;
}

.mobile-menu-links li {
  margin: 0;
  padding: 0;
}

.mobile-menu-links a {
  display: block;
  padding: 12px 0;
  font-family: "Roboto Mono", monospace;
  font-size: 18px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  text-decoration: none;
  color: #111111;
}

body.menu-open {
  overflow: hidden;
}

@media (max-width: 768px) {
  .desktop-nav-container,
  .duplex-coords {
    display: none;
  }

  .mobile-menu-button {
    display: inline-flex;
  }

  .duplex-mobile-popup,
  .duplex-mobile-popup.is-open {
    position: fixed !important;
    inset: 0 !important;
    top: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    left: 0 !important;
    width: 100vw !important;
    min-width: 100vw !important;
    max-width: 100vw !important;
    height: 100dvh !important;
    min-height: 100dvh !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    overflow-y: auto !important;
  }

  .mobile-popup-inner {
    width: 100% !important;
    max-width: none !important;
    min-height: 100dvh !important;
    margin: 0 !important;
    padding: 32px 24px calc(24px + env(safe-area-inset-bottom)) 24px !important;
    border-radius: 0 !important;
    box-shadow: none !important;
  }
}

/* 🏛️ Logo z-index */
.duplex-header-v8 .wp-block-site-logo,
.duplex-header-v8 .wp-block-site-logo a,
.duplex-header-v8 .wp-block-site-logo img,
.duplex-header-v8 .custom-logo-link,
.duplex-header-v8 .custom-logo {
  z-index: 10000 !important;
  position: relative !important;
}

header {
    z-index: 99;
}

/* Contact Button (Technical Outline) */
.duplex-btn-contact-v8 .wp-block-button__link {
  background: transparent !important;
  border-radius: 0px !important;
  padding: 12px 24px !important;
  font-family: "Roboto Mono", monospace !important;
  font-size: 10px !important;
  color: #111111 !important;
  border: 1px solid #111111 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.2em !important;
  transition: all 0.3s ease !important;
}

.duplex-btn-contact-v8 .wp-block-button__link:hover {
  background: #111111 !important;
  color: #ffffff !important;
}

/* 🚫 REMOVE FOCUS OUTLINES (As requested) */
a:focus,
button:focus,
.wp-block-button__link:focus,
a:focus-visible,
button:focus-visible {
  outline: none !important;
  box-shadow: none !important;
}

/* Hero Fidelity Adjustments */
.duplex-hero-technical {
  position: relative !important;
  padding: 160px 0 100px 0 !important;
}

.hero-technical-title {
  font-size: clamp(4rem, 10vw, 8rem) !important;
  margin: 40px 0 !important;
}

/* 🏗️ PROJECT CARDS (Archive Projeto) - 1:1 con React */

/* Grid de 3 columnas */
.duplex-projects-grid {
  display: grid !important;
  grid-template-columns: repeat(1, 1fr) !important;
  gap: 32px !important;
}

@media (min-width: 768px) {
  .duplex-projects-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

@media (min-width: 1024px) {
  .duplex-projects-grid {
    grid-template-columns: repeat(3, 1fr) !important;
  }
}

.duplex-project-card {
  transition: all 0.4s ease !important;
  position: relative;
  overflow: hidden;
  background: #ffffff !important;
  cursor: pointer;
}

.duplex-project-card-image {
  aspect-ratio: 4/3 !important;
  height: auto !important;
  width: 100% !important;
  object-fit: cover !important;
  transition: transform 0.6s ease !important;
  position: relative;
}

.duplex-project-card:hover .duplex-project-card-image img {
  transform: scale(1.08) !important;
}

.duplex-project-card-image img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
}

.duplex-project-category {
  display: block !important;
  margin-bottom: 8px !important;
}

.duplex-project-meta {
  display: flex !important;
  align-items: center !important;
  gap: 4px !important;
}

/* Hover gradient overlay (igual que React) */
.duplex-project-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    var(--duplex-primary) 0%,
    var(--duplex-primary) / 50 50%,
    transparent 100%
  );
  opacity: 0;
  transition: opacity 0.4s ease;
  pointer-events: none;
  z-index: 10;
}

.duplex-project-card:hover::before {
  opacity: 1;
}

/* Corner accent (orange square rotated 45deg) */
.duplex-project-corner-accent {
  position: absolute;
  top: 0;
  right: 0;
  width: 80px;
  height: 80px;
  background: var(--duplex-accent);
  transform: scale(0) rotate(45deg);
  transform-origin: top right;
  transition: transform 0.4s ease;
  z-index: 11;
}

.duplex-project-card:hover .duplex-project-corner-accent {
  transform: scale(1) rotate(45deg);
}

/* Hover content overlay (texto blanco) */
.duplex-project-hover-overlay {
  position: absolute;
  inset: 0;
  z-index: 12;
  opacity: 0;
  transition: opacity 0.4s ease;
  pointer-events: none;
}

.duplex-project-card:hover .duplex-project-hover-overlay {
  opacity: 1;
}

.duplex-project-hover-overlay * {
  color: #ffffff !important;
}

.duplex-project-hover-overlay svg {
  stroke: #ffffff !important;
}

/* Hover content animation */
.duplex-project-hover-overlay {
  transform: translateY(20px);
}

.duplex-project-card:hover .duplex-project-hover-overlay {
  transform: translateY(0);
}

/* Info bar */
.duplex-project-card > .wp-block-group:last-child {
  position: relative;
  z-index: 13;
  background: #ffffff;
}

/* Top border animation en info bar */
.duplex-project-card > .wp-block-group:last-child::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  height: 2px;
  width: 0%;
  background: linear-gradient(
    to right,
    var(--duplex-accent),
    var(--duplex-primary)
  );
  transition: width 0.4s ease;
  z-index: 14;
}

.duplex-project-card:hover > .wp-block-group:last-child::before {
  width: 100%;
}

/* Filter buttons (Tabs) */
.duplex-projetos-filters {
  position: sticky !important;
  top: 80px !important;
  z-index: 100 !important;
  background: #ffffff !important;
}

.duplex-filter-tab .wp-block-button__link {
  border-radius: 0 !important;
  font-family: "Roboto Mono", monospace !important;
  font-size: 14px !important;
  letter-spacing: 0.05em !important;
  text-transform: uppercase !important;
  border: 1px solid rgba(0, 0, 0, 0.2) !important;
  background: transparent !important;
  color: #111111 !important;
  padding: 8px 24px !important;
  transition: all 0.3s ease !important;
  cursor: pointer !important;
}

.duplex-filter-tab.active .wp-block-button__link,
.duplex-filter-tab .wp-block-button__link[data-category="all"] {
  background: var(--duplex-primary) !important;
  color: #ffffff !important;
  border-color: var(--duplex-primary) !important;
}

.duplex-filter-tab .wp-block-button__link:hover {
  border-color: var(--duplex-accent) !important;
  color: var(--duplex-accent) !important;
}

.duplex-filter-tab {
  appearance: none !important;
  border-radius: 999px !important;
  border: 1px solid rgba(17, 17, 17, 0.10) !important;
  background: #ffffff !important;
  color: rgba(17, 17, 17, 0.58) !important;
  font-family: "Roboto Mono", monospace !important;
  font-size: 10px !important;
  font-weight: 500 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  padding: 11px 18px !important;
  min-height: 42px !important;
  line-height: 1 !important;
  box-shadow: none !important;
  transition: all 0.25s ease !important;
  cursor: pointer !important;
}

.duplex-filter-tab:hover {
  color: #ff6b35 !important;
  border-color: rgba(255, 107, 53, 0.35) !important;
}

.duplex-filter-tab.active {
  background: #111111 !important;
  color: #ffffff !important;
  border-color: #111111 !important;
}

/* CTA Button with accent border */
.duplex-cta-button {
  border-bottom: 2px solid var(--duplex-accent) !important;
  color: var(--duplex-accent) !important;
}

.duplex-cta-button:hover {
  border-bottom-color: var(--duplex-accent) !important;
  color: var(--duplex-accent) !important;
}

/* No results message */
.duplex-no-results {
  display: none;
}

.duplex-no-results.active {
  display: block !important;
}

/* Projects grid hidden when filtering */
.duplex-projects-grid.hidden {
  display: none !important;
}

/* 🏗️ SINGLE PROJETO VIEW (V10 Technical) */
.duplex-single-hero {
  position: relative;
  padding: 200px 5% 150px 5%;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  display: flex;
  align-items: flex-end;
  min-height: 80vh;
  overflow: hidden;
}

.duplex-single-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgba(0, 0, 0, 0.8) 0%,
    rgba(0, 0, 0, 0.3) 50%,
    rgba(0, 0, 0, 0.1) 100%
  );
  z-index: 1;
}

.duplex-single-hero .grid-overlay {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.08) 1px, transparent 1px);
  background-size: 96px 96px;
  opacity: 0.26;
  z-index: 2;
  pointer-events: none;
}

.duplex-single-hero .hero-content {
  position: relative;
  z-index: 10;
  max-width: 1200px;
  margin: 0 auto;
  width: 100%;
}

.duplex-single-hero .architectural-tag-row .tag,
.duplex-single-hero .hero-technical-title,
.duplex-single-hero .hero-technical-subtitle {
  color: #ffffff !important;
}

.duplex-single-hero .architectural-tag-row .technical-line {
  background: rgba(255, 255, 255, 0.2) !important;
}

.duplex-single-data {
  padding: 110px 5%;
  position: relative;
  background: #ffffff;
  overflow: hidden;
}

.duplex-single-data::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(17, 17, 17, 0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(17, 17, 17, 0.035) 1px, transparent 1px);
  background-size: 96px 96px;
  pointer-events: none;
}

.duplex-single-container {
  max-width: 1200px;
  margin: 0 auto;
  position: relative;
  z-index: 10;
}

.duplex-data-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 64px;
}

@media (min-width: 1024px) {
  .duplex-data-grid {
    grid-template-columns: 350px 1fr;
  }
}

.duplex-meta-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.duplex-meta-list li {
  padding: 24px 0;
  border-bottom: 1px solid var(--duplex-border);
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.duplex-meta-list li:first-child {
  border-top: 1px solid var(--duplex-border);
}

.duplex-meta-list .meta-label {
  font-family: "Roboto Mono", monospace;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: var(--duplex-accent);
}

.duplex-meta-list .meta-value {
  font-family: "Montserrat", sans-serif;
  font-weight: 300;
  font-size: 18px;
  color: var(--duplex-text);
}

/* Content Area inside Single */
.the-content-area p {
  font-family: "Open Sans", sans-serif;
  font-size: 16px;
  line-height: 1.8;
  color: rgba(17, 17, 17, 0.7);
  margin-bottom: 32px;
}

.the-content-area img {
  max-width: 100%;
  height: auto;
}

/* 🌀 HIGH-FIDELITY ANIMATIONS (GSAP READY) */
.reveal-up {
  opacity: 0;
  transform: translateY(40px);
}

.architectural-grid-2-5-5 {
  display: grid !important;
  grid-template-columns: 2fr 5fr 5fr !important;
  gap: 64px !important;
  align-items: start !important;
}

@media (max-width: 1024px) {
  .architectural-grid-2-5-5 {
    grid-template-columns: 1fr !important;
    gap: 40px !important;
  }
}

.parallax-watermark {
  position: absolute !important;
  font-family: "Montserrat", sans-serif !important;
  font-weight: 900 !important;
  font-size: clamp(10rem, 25vw, 40rem) !important;
  color: rgba(0, 0, 0, 0.03) !important;
  line-height: 0.8 !important;
  letter-spacing: -0.05em !important;
  z-index: -1 !important;
  pointer-events: none !important;
  white-space: nowrap !important;
}

/* 🏗️ Internal Page Hero Redesign */
.duplex-internal-hero {
  padding: 180px 64px 80px 64px !important;
  background: #ffffff !important;
  position: relative !important;
  overflow: hidden !important;
}

.internal-hero-tag {
  font-family: "Roboto Mono", monospace !important;
  font-size: 10px !important;
  letter-spacing: 0.4em !important;
  color: var(--duplex-accent) !important;
  text-transform: uppercase !important;
}

.internal-hero-title {
  font-family: "Montserrat", sans-serif !important;
  font-weight: 200 !important;
  font-size: clamp(3rem, 7vw, 6rem) !important;
  line-height: 0.9 !important;
  letter-spacing: -0.04em !important;
  margin-top: 24px !important;
  text-transform: uppercase !important;
}

/* 🏷️ Technical Tag Row */
.architectural-tag-row {
  display: flex !important;
  align-items: center !important;
  gap: 24px !important;
  margin-bottom: 24px !important;
}

.tag-line {
  height: 1px !important;
  background: var(--duplex-border) !important;
  flex-grow: 1 !important;
}

/* 🖼️ HIGH-FIDELITY PROJECT CARDS (V10 REACT SPIRIT) */
.duplex-project-card-v10 {
  background: #ffffff !important;
  position: relative !important;
  overflow: hidden !important;
  cursor: pointer !important;
}

.card-image-content {
  position: relative !important;
  aspect-ratio: 4/3 !important;
  overflow: hidden !important;
  background: #f8f8f8 !important;
}

.card-main-img {
  width: 100% !important;
  height: 100% !important;
  top: 0 !important;
  left: 0 !important;
  object-fit: cover !important;
  transition: transform 0.8s cubic-bezier(0.16, 1, 0.3, 1) !important;
}

.duplex-project-card-v10:hover .card-main-img {
  transform: scale(1.08) !important;
}

.card-overlay {
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(
    to top,
    rgba(43, 61, 79, 0.9),
    rgba(43, 61, 79, 0.4),
    transparent
  ) !important;
  opacity: 0 !important;
  transition: opacity 0.5s ease !important;
}

.duplex-project-card-v10:hover .card-overlay {
  opacity: 1 !important;
}

.card-hover-info {
  position: absolute !important;
  inset: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-end !important;
  padding: 32px !important;
  color: white !important;
  opacity: 0 !important;
  transform: translateY(20px) !important;
  transition: all 0.5s cubic-bezier(0.16, 1, 0.3, 1) !important;
  z-index: 2 !important;
}

.duplex-project-card-v10:hover .card-hover-info {
  opacity: 1 !important;
  transform: translateY(0) !important;
}

.card-hover-title {
  font-family: "Montserrat", sans-serif !important;
  font-weight: 200 !important;
  font-size: 24px !important;
  margin-bottom: 12px !important;
  color: white !important;
  text-transform: uppercase !important;
}

.card-hover-meta {
  display: flex !important;
  gap: 20px !important;
  font-size: 12px !important;
  opacity: 0.8 !important;
}

.card-corner-accent {
  position: absolute !important;
  top: 0 !important;
  right: 0 !important;
  width: 60px !important;
  height: 60px !important;
  background: var(--duplex-accent) !important;
  transform: translate(50%, -50%) rotate(45deg) !important;
  transition: transform 0.5s cubic-bezier(0.16, 1, 0.3, 1) !important;
  z-index: 1 !important;
}

.duplex-project-card-v10:hover .card-corner-accent {
  transform: translate(0, 0) rotate(45deg) !important;
}

.card-info-bar {
  padding: 24px !important;
  background: white !important;
  position: relative !important;
}

.card-info-border {
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  height: 2px !important;
  width: 0 !important;
  background: linear-gradient(
    to right,
    var(--duplex-accent),
    var(--duplex-primary)
  ) !important;
  transition: width 0.6s cubic-bezier(0.16, 1, 0.3, 1) !important;
}

.duplex-project-card-v10:hover .card-info-border {
  width: 100% !important;
}

.card-info-flex {
  display: flex !important;
  justify-content: space-between !important;
  align-items: flex-end !important;
}

.card-cat-tag {
  font-family: "Roboto Mono", monospace !important;
  font-size: 10px !important;
  color: var(--duplex-accent) !important;
  letter-spacing: 0.1em !important;
  display: block !important;
  margin-bottom: 8px !important;
}

.card-title-v10 {
  font-family: "Montserrat", sans-serif !important;
  font-weight: 300 !important;
  font-size: 18px !important;
  color: var(--duplex-primary) !important;
  text-transform: uppercase !important;
  margin: 0 !important;
}

.card-title-v10 a {
  text-decoration: none !important;
  color: inherit !important;
  transition: color 0.3s ease !important;
}

.duplex-project-card-v10:hover .card-title-v10 a {
  color: var(--duplex-accent) !important;
}

.card-year-tag {
  font-family: "Roboto Mono", monospace !important;
  font-size: 12px !important;
  color: rgba(0, 0, 0, 0.3) !important;
}
/* 🎯 HIGH-FIDELITY PROJECT FILTERS (REACT SPIRIT) */
.duplex-filter-v10-container {
  padding: 32px 0 !important;
  border-bottom: 1px solid rgba(0, 0, 0, 0.05) !important;
  position: sticky !important;
  top: 70px !important;
  background: white !important;
  z-index: 50 !important;
}

.duplex-filter-v10-scroll {
  display: flex !important;
  justify-content: center !important;
  gap: 12px !important;
  overflow-x: auto !important;
  scrollbar-width: none !important;
}

.duplex-filter-v10-scroll::-webkit-scrollbar {
  display: none !important;
}

.filter-tab-v10 {
  background: white !important;
  border: 1px solid rgba(0, 0, 0, 0.1) !important;
  padding: 12px 24px !important;
  font-family: "Roboto Mono", monospace !important;
  font-size: 10px !important;
  letter-spacing: 0.15em !important;
  cursor: pointer !important;
  transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1) !important;
  color: rgba(0, 0, 0, 0.4) !important;
}

.filter-tab-v10:hover {
  border-color: var(--duplex-accent) !important;
  color: var(--duplex-accent) !important;
}

.filter-tab-v10.active {
  background: var(--duplex-primary) !important;
  color: white !important;
  border-color: var(--duplex-primary) !important;
}

/* 🏛️ HIGH-FIDELITY INTERNAL HERO (HOME SPIRIT) */
.duplex-internal-hero {
  position: relative !important;
  padding: 160px 64px 100px 64px !important;
  background: #ffffff !important;
  overflow: hidden !important;
}

/* Internal Grid Background (0.02 opacity match from Home) */
.duplex-internal-hero::before {
  content: "" !important;
  position: absolute !important;
  inset: -100px !important;
  opacity: 0.02 !important;
  background-image:
    linear-gradient(rgba(0, 0, 0, 1) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0, 0, 0, 1) 1px, transparent 1px) !important;
  background-size: 100px 100px !important;
  z-index: 1 !important;
  pointer-events: none !important;
}

.duplex-internal-hero h1 {
  font-family: "Montserrat", sans-serif !important;
  font-weight: 200 !important;
  font-size: clamp(3.5rem, 10vw, 9rem) !important;
  line-height: 0.85 !important;
  letter-spacing: -0.04em !important;
  text-transform: uppercase !important;
  margin-bottom: 40px !important;
  position: relative !important;
  z-index: 2 !important;
}

.duplex-internal-hero p {
  font-size: 22px !important;
  font-weight: 300 !important;
  color: rgba(0, 0, 0, 0.6) !important;
  max-width: 800px !important;
  line-height: 1.5 !important;
  position: relative !important;
  z-index: 2 !important;
}

/* 🏗️ GRID PROJECT FIDELITY */
.featured-project-card:hover .grid-project-img {
  filter: grayscale(0%) !important;
  transform: scale(1.05) !important;
}

.featured-project-card:hover {
  background: #fafafa !important;
}

.featured-project-card h3 a:hover {
  color: var(--duplex-accent) !important;
}

/* 🏛️ PRESS GRID (V10 Technical) */
.duplex-press-container {
  padding: 0 64px;
}

.duplex-press-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(400px, 1fr)) !important;
  gap: 1px !important;
  background: rgba(0, 0, 0, 0.05) !important;
}

.press-article-card {
  background: white !important;
  padding: 48px !important;
  border-right: 1px solid rgba(0, 0, 0, 0.05) !important;
  transition: background 0.3s ease !important;
}

.press-article-card:hover {
  background: #fafafa !important;
}

.press-article-inner {
  display: flex !important;
  flex-direction: column !important;
  gap: 32px !important;
}

.press-cat {
  font-family: "Roboto Mono", monospace !important;
  font-size: 10px !important;
  color: var(--duplex-accent) !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
}

.press-image-wrap {
  aspect-ratio: 16/9 !important;
  overflow: hidden !important;
  background: #f8f8f8 !important;
}

.press-img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  transition: all 0.5s ease !important;
  filter: grayscale(100%) !important;
}

.press-article-card:hover .press-img {
  filter: grayscale(0%) !important;
  transform: scale(1.05) !important;
}

.press-date {
  font-family: "Roboto Mono", monospace !important;
  font-size: 11px !important;
  color: rgba(0, 0, 0, 0.3) !important;
}

.press-title {
  font-family: "Montserrat", sans-serif !important;
  font-weight: 200 !important;
  font-size: 28px !important;
  margin: 12px 0 !important;
  line-height: 1.2 !important;
}

.press-excerpt {
  font-family: "Open Sans", sans-serif !important;
  font-size: 14px !important;
  line-height: 1.6 !important;
  color: rgba(0, 0, 0, 0.6) !important;
  margin-bottom: 24px !important;
}

.press-link {
  font-family: "Roboto Mono", monospace !important;
  font-size: 11px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.2em !important;
  color: black !important;
  text-decoration: none !important;
  border-bottom: 1px solid var(--duplex-accent) !important;
  padding-bottom: 4px !important;
}

.press-empty {
  padding: 48px !important;
  text-align: center !important;
  background: white !important;
}

/* 📱 MOBILE RESPONSIVENESS (V11) */
@media (max-width: 1024px) {
  .duplex-projects-grid,
  .duplex-featured-grid {
    grid-template-columns: 1fr !important;
  }

  .duplex-projects-grid article,
  .duplex-featured-grid article {
    border-right: none !important;
    border-bottom: 1px solid rgba(0, 0, 0, 0.05) !important;
    padding: 40px 24px !important;
  }

  .duplex-internal-hero {
    padding: 120px 24px 60px 24px !important;
  }

  .duplex-internal-hero h1 {
    font-size: 4rem !important;
  }

  .duplex-label-row {
    padding: 0 24px !important;
  }
}

/* Fix for narrow grid items */
.duplex-projects-grid article:nth-child(even) {
  border-right: none !important;
}

@media (min-width: 1025px) {
  .duplex-projects-grid article:nth-child(3n) {
    border-right: none !important;
  }
}

/* ========================================
   📱 COMPLETE RESPONSIVE DESIGN (V12)
   ======================================== */

.duplex-footer-v8 {
  background: #ffffff;
  box-sizing: border-box;
  padding: 96px clamp(22px, 4vw, 48px) 40px;
  border-top: 1px solid rgba(0, 0, 0, 0.05);
}

.footer-main-grid {
  max-width: 1800px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(280px, 1.15fr) minmax(180px, 0.7fr) minmax(280px, 1fr);
  gap: 72px;
  align-items: start;
}

.footer-logo-wrap {
  display: inline-flex;
  align-items: center;
}

.footer-description {
  margin: 0 0 36px;
  max-width: 320px;
  font-family: "Open Sans", sans-serif;
  font-size: 16px;
  line-height: 1.7;
  color: rgba(17, 17, 17, 0.68);
}

.footer-location {
  display: flex;
  align-items: center;
  gap: 14px;
}

.footer-line {
  width: 40px;
  height: 1px;
  background: rgba(255, 107, 53, 0.5);
  flex-shrink: 0;
}

.footer-city,
.footer-label,
.footer-coords-bottom,
.copyright-mono {
  font-family: "Roboto Mono", monospace;
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.footer-city {
  color: rgba(17, 17, 17, 0.58);
}

.footer-label {
  display: inline-block;
  margin-bottom: 24px;
  color: #ff6b35;
}

.duplex-footer-nav-list,
.duplex-footer-nav {
  list-style: none;
  padding: 0;
  margin: 0;
}

.duplex-footer-nav-list li,
.duplex-footer-nav li {
  margin-bottom: 12px;
}

.duplex-footer-nav-list a,
.duplex-footer-nav a {
  font-family: "Roboto Mono", monospace;
  font-size: 11px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: rgba(0, 0, 0, 0.42);
  text-decoration: none;
  transition: color 0.3s ease;
  position: relative;
  display: inline-block;
  padding: 8px 0;
}

.duplex-footer-nav-list a::after,
.duplex-footer-nav a::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 0;
  height: 1px;
  background: #ff6b35;
  transition: width 0.3s ease;
}

.duplex-footer-nav-list a:hover,
.duplex-footer-nav-list .current-menu-item > a,
.duplex-footer-nav-list .current_page_item > a,
.duplex-footer-nav a:hover,
.duplex-footer-nav .current-menu-item > a,
.duplex-footer-nav .current_page_item > a {
  color: #111111;
}

.duplex-footer-nav-list a:hover::after,
.duplex-footer-nav-list .current-menu-item > a::after,
.duplex-footer-nav-list .current_page_item > a::after,
.duplex-footer-nav a:hover::after,
.duplex-footer-nav .current-menu-item > a::after,
.duplex-footer-nav .current_page_item > a::after {
  width: 100%;
}

.footer-contact-item {
  color: #111111;
}

.contact-info-block {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.contact-email,
.contact-address {
  font-family: "Open Sans", sans-serif;
  font-size: 16px;
  line-height: 1.7;
  color: rgba(17, 17, 17, 0.7);
}

.footer-bottom-bar {
  border-top: 1px solid rgba(0, 0, 0, 0.05);
  margin-top: 72px;
  padding-top: 22px;
}

.footer-bottom-container {
  max-width: 1800px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}

.footer-copyright,
.footer-credits {
  font-family: "Open Sans", sans-serif;
  font-size: 12px;
  line-height: 1.6;
  color: rgba(17, 17, 17, 0.62);
}

.footer-credits {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.credit-divider {
  color: rgba(17, 17, 17, 0.28);
}

/* Footer Navigation Styles */
.duplex-footer-nav {
  list-style: none;
  padding: 0;
  margin: 0;
}

.duplex-footer-nav li {
  margin-bottom: 16px;
}

.duplex-footer-nav a {
  font-family: 'Roboto Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: rgba(0, 0, 0, 0.3);
  text-decoration: none;
  transition: color 0.3s ease;
  position: relative;
  display: inline-block;
  padding: 8px 0;
}

.duplex-footer-nav a:hover,
.duplex-footer-nav li.current-menu-item a,
.duplex-footer-nav li.current_page_item a {
  color: #111;
}

/* Orange underline animation */
.duplex-footer-nav a::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 0;
  height: 1px;
  background: #FF6B35;
  transition: width 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.duplex-footer-nav a:hover::after,
.duplex-footer-nav li.current-menu-item a::after,
.duplex-footer-nav li.current_page_item a::after {
  width: 100%;
}

/* Footer Responsive */
@media (max-width: 1200px) {
  .duplex-footer-v8 {
    padding-left: 40px !important;
    padding-right: 40px !important;
  }
  
  .duplex-footer-v8 > div:first-child {
    gap: 60px !important;
  }
}

@media (max-width: 992px) {
  .duplex-footer-v8 > div:first-child {
    grid-template-columns: 1fr 1fr !important;
    gap: 60px !important;
  }
  
  .footer-brand-col {
    grid-column: 1 / -1;
  }
  
  .footer-nav-col {
    grid-column: 1 / 2;
  }
  
  .footer-contact-col {
    grid-column: 2 / -1;
  }
}

@media (max-width: 768px) {
  .duplex-footer-v8 {
    display: block !important;
    width: 100% !important;
    box-sizing: border-box !important;
    margin-top: 56px !important;
    padding: 72px 24px 32px !important;
    position: relative !important;
    z-index: 1 !important;
    clear: both !important;
    overflow: visible !important;
  }
  
  .duplex-footer-v8 > div:first-child {
    grid-template-columns: 1fr !important;
    gap: 40px !important;
  }
  
  .footer-brand-col,
  .footer-nav-col,
  .footer-contact-col {
    grid-column: 1 / -1;
    min-width: 0 !important;
  }
  
  /* Bottom bar responsive */
  .duplex-footer-v8 > div:last-child {
    flex-direction: column;
    gap: 12px;
    text-align: left;
    align-items: flex-start;
  }

  .footer-main-grid,
  .footer-bottom-container {
    width: 100% !important;
    max-width: none !important;
    position: relative !important;
    z-index: 2 !important;
  }

  .footer-main-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
  }

  .footer-bottom-bar {
    margin-top: 40px !important;
    padding-top: 18px !important;
  }

  .footer-logo-wrap,
  .footer-location,
  .footer-credits {
    float: none !important;
    clear: none !important;
    width: auto !important;
    max-width: none !important;
  }

  .footer-logo-wrap img {
    max-width: 100px !important;
    height: auto !important;
  }

  .footer-description,
  .footer-contact-item,
  .duplex-footer-nav-list,
  .duplex-footer-nav-list li,
  .duplex-footer-nav-list a,
  .footer-copyright,
  .footer-coords-bottom,
  .contact-email,
  .contact-address {
    float: none !important;
    clear: both !important;
    width: 100% !important;
    max-width: 100% !important;
    word-break: break-word !important;
  }
}

/* Contact Page Responsive */
@media (max-width: 1200px) {
  .duplex-tech-form {
    max-width: 100%;
  }
}

@media (max-width: 992px) {
  /* Contact page columns */
  .site-main > section:first-child > div > div {
    grid-template-columns: 1fr !important;
    gap: 60px !important;
  }
  
  .site-main h2 {
    font-size: 48px !important;
  }
}

@media (max-width: 768px) {
  /* Contact page */
  .site-main > section:first-child {
    padding: 80px 24px !important;
  }
  
  .site-main h2 {
    font-size: 40px !important;
  }
  
  .mono-text {
    font-size: 14px !important;
  }
  
  /* Contact map responsive only */
  .page-id-674 .site-main > section:last-child {
    height: 400px !important;
  }
  
  /* Form inputs responsive */
  .wpcf7-text,
  .wpcf7-email,
  .wpcf7-textarea,
  .forminator-form .forminator-input,
  .forminator-form .forminator-textarea {
    font-size: 16px !important; /* Prevents zoom on iOS */
  }
}

@media (max-width: 480px) {
  .site-main h2 {
    font-size: 32px !important;
  }
  
  .site-main > section:first-child {
    padding: 60px 20px !important;
  }
}

/* General Mobile Responsive Improvements */
@media (max-width: 768px) {
  /* Hero sections */
  .hero-technical-title {
    font-size: 40px !important;
  }

  /* Grid layouts */
  [style*="grid-template-columns"] {
    grid-template-columns: 1fr !important;
  }

  /* Padding adjustments */
  .wp-block-group[style*="padding:120px"] {
    padding: 60px 24px !important;
  }

  /* Large text adjustments */
  [style*="font-size:64px"] {
    font-size: 40px !important;
  }

  [style*="font-size:48px"] {
    font-size: 32px !important;
  }

  /* Images responsive */
  img {
    max-width: 100%;
    height: auto;
  }
  
  /* Press & Servicos cards */
  .servico-card,
  .press-article-card {
    margin: 16px 0 !important;
  }
  
  .servico-card [style*="padding: 64px"],
  .press-article-card [style*="padding: 48px"] {
    padding: 32px 24px !important;
  }
  
  .servico-card h2,
  .press-title {
    font-size: 28px !important;
  }
}

/* Tablet adjustments */
@media (min-width: 769px) and (max-width: 1024px) {
  .hero-technical-title {
    font-size: 48px !important;
  }
  
  .duplex-featured-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

/* Print styles */
@media print {
  .duplex-footer-v8,
  .site-header {
    display: none;
  }
}

/* ========================================
   📱 HEADER RESPONSIVE - MOBILE MENU
   ======================================== */

/* Mobile menu button (hamburger) */
.wp-block-navigation__responsive-container-open {
    display: none !important;
}

@media (max-width: 768px) {
    /* Show hamburger menu on mobile */
    .wp-block-navigation__responsive-container-open {
        display: flex !important;
        background: transparent !important;
        border: none !important;
        padding: 8px !important;
        cursor: pointer !important;
    }
    
    .wp-block-navigation__responsive-container-open svg {
        fill: #000 !important;
        width: 24px !important;
        height: 24px !important;
    }
    
    /* Mobile navigation container */
    .wp-block-navigation__responsive-container {
    }
    
    /* Mobile menu items */
    .wp-block-navigation__responsive-container .wp-block-navigation-item__label {
        font-size: 16px !important;
        padding: 16px !important;
    }
    
    /* Header padding mobile */
    .duplex-header-v8 > div {
        padding-left: 24px !important;
        padding-right: 24px !important;
    }
}

/* ========================================
   📄 INTERNAL PAGE HERO STYLES
   ======================================== */
.duplex-internal-hero {
    padding: 120px 64px !important;
    border-top: 1px solid rgba(0,0,0,0.05) !important;
}

.duplex-internal-hero h1 {
    font-family: 'Montserrat', sans-serif !important;
    font-weight: 200 !important;
    font-size: 64px !important;
    line-height: 1.1 !important;
    margin-bottom: 24px !important;
}

.duplex-internal-hero p {
    font-family: 'Open Sans', sans-serif !important;
    font-weight: 300 !important;
    font-size: 18px !important;
    color: rgba(0,0,0,0.6) !important;
    max-width: 800px !important;
}

.duplex-internal-hero span[style*="letter-spacing"] {
    font-family: 'Roboto Mono', monospace !important;
    font-size: 10px !important;
    letter-spacing: 0.3em !important;
    color: #FF6B35 !important;
    text-transform: uppercase !important;
}

@media (max-width: 768px) {
    .duplex-internal-hero {
        padding: 80px 24px !important;
    }
    .duplex-internal-hero h1 {
        font-size: 40px !important;
    }
}

/* ========================================
   📄 CORRECCIÓN FUENTES Y ANIMACIONES
   ======================================== */

/* Títulos de páginas internas - FUENTE CORRECTA */
.duplex-internal-hero h1 {
    font-family: 'Montserrat', sans-serif !important;
    font-weight: 200 !important;
    font-size: clamp(3rem, 10vw, 6rem) !important;
    line-height: 0.85 !important;
    letter-spacing: -0.04em !important;
    text-transform: uppercase !important;
    margin-bottom: 24px !important;
}

.duplex-internal-hero p {
    font-family: 'Open Sans', sans-serif !important;
    font-weight: 300 !important;
    font-size: clamp(1.2rem, 2.5vw, 1.8rem) !important;
    line-height: 1.6 !important;
    color: rgba(0,0,0,0.6) !important;
    max-width: 800px !important;
}

.duplex-internal-hero span[style*="letter-spacing"],
.duplex-internal-hero span[class*="text-"] {
    font-family: 'Roboto Mono', monospace !important;
    font-size: 10px !important;
    letter-spacing: 0.3em !important;
    color: #FF6B35 !important;
    text-transform: uppercase !important;
    display: block !important;
    margin-bottom: 32px !important;
}

/* Animaciones para títulos */
.duplex-internal-hero .reveal-up {
    animation: revealUp 0.8s cubic-bezier(0.16, 1, 0.3, 1) forwards;
    opacity: 0;
    transform: translateY(30px);
}

.duplex-internal-hero .reveal-up:nth-child(1) { animation-delay: 0.1s; }
.duplex-internal-hero .reveal-up:nth-child(2) { animation-delay: 0.3s; }
.duplex-internal-hero .reveal-up:nth-child(3) { animation-delay: 0.5s; }

@keyframes revealUp {
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@media (max-width: 768px) {
    .duplex-internal-hero {
        padding: 80px 24px !important;
    }
    .duplex-internal-hero h1 {
        font-size: 40px !important;
        line-height: 1.1 !important;
    }
}


header {
    z-index: 99;
}

/* ==============================================================================
   INTERNAL V2 CANONICAL LAYOUT
   Keep shared internal-page structure in theme CSS, not in page content.
   ============================================================================== */
:root {
    --duplex-v2-max: 1320px;
    --duplex-v2-shell-pad: clamp(22px, 3.6vw, 56px);
    --duplex-v2-hero-top: clamp(42px, 4.8vw, 64px);
    --duplex-v2-hero-bottom: clamp(28px, 3.6vw, 44px);
    --duplex-v2-section-y: clamp(68px, 7vw, 100px);
}

.page-id-666 .duplex-about-hero,
.page-id-671 .duplex-v2-hero,
.page-id-672 .duplex-v2-hero,
.page-id-673 .duplex-v2-hero,
.page-id-674 .duplex-v2-hero {
    padding-top: 6px !important;
}

.page-id-666 .duplex-about-hero > .wp-block-group,
.page-id-671 .duplex-v2-hero > .wp-block-group,
.page-id-672 .duplex-v2-hero > .wp-block-group,
.page-id-673 .duplex-v2-hero > .wp-block-group,
.page-id-674 .duplex-v2-hero > .wp-block-group {
    max-width: var(--duplex-v2-max) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-top: var(--duplex-v2-hero-top) !important;
    padding-bottom: var(--duplex-v2-hero-bottom) !important;
    padding-left: var(--duplex-v2-shell-pad) !important;
    padding-right: var(--duplex-v2-shell-pad) !important;
    text-align: center !important;
}

.page-id-666 .duplex-about-hero .wp-block-paragraph,
.page-id-671 .duplex-v2-hero .wp-block-paragraph,
.page-id-672 .duplex-v2-hero .wp-block-paragraph,
.page-id-673 .duplex-v2-hero .wp-block-paragraph,
.page-id-674 .duplex-v2-hero .wp-block-paragraph {
    margin-left: auto !important;
    margin-right: auto !important;
    text-align: center !important;
}

.page-id-666 .duplex-about-hero .wp-block-heading,
.page-id-671 .duplex-v2-hero .wp-block-heading,
.page-id-672 .duplex-v2-hero .wp-block-heading,
.page-id-673 .duplex-v2-hero .wp-block-heading,
.page-id-674 .duplex-v2-hero .wp-block-heading {
    margin-bottom: 16px !important;
    line-height: 0.95 !important;
    text-align: center !important;
}

.page-id-671 .duplex-v2-shell,
.page-id-672 .duplex-v2-shell,
.page-id-673 .duplex-v2-shell,
.page-id-674 .duplex-v2-contact-columns,
.page-id-666 .duplex-about-section {
    padding-left: var(--duplex-v2-shell-pad) !important;
    padding-right: var(--duplex-v2-shell-pad) !important;
}

.page-id-671 .duplex-v2-grid-shell,
.page-id-672 .duplex-v2-grid-shell,
.page-id-673 .duplex-v2-grid-shell,
.page-id-674 .duplex-v2-contact-columns,
.page-id-666 .duplex-about-grid {
    max-width: var(--duplex-v2-max) !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

.page-id-671 .duplex-v2-shell,
.page-id-672 .duplex-v2-shell,
.page-id-673 .duplex-v2-shell {
    padding-top: 30px !important;
}

.page-id-671 .duplex-filter-v10-container,
.page-id-672 .duplex-filter-v10-container,
.page-id-673 .duplex-filter-v10-container {
    margin-top: 10px !important;
    margin-bottom: 34px !important;
    display: flex !important;
    justify-content: center !important;
}

.page-id-671 .duplex-filter-v10-scroll,
.page-id-672 .duplex-filter-v10-scroll,
.page-id-673 .duplex-filter-v10-scroll {
    justify-content: center !important;
    gap: 14px !important;
}

.page-id-666 .duplex-about-intro {
    max-width: 760px !important;
    font-size: clamp(1.18rem, 1.65vw, 1.7rem) !important;
    line-height: 1.45 !important;
}

.page-id-666 .duplex-about-section {
    padding-top: clamp(70px, 7vw, 102px) !important;
    padding-bottom: clamp(70px, 7vw, 102px) !important;
}

.page-id-666 .duplex-about-heading {
    font-size: clamp(2.15rem, 4.2vw, 3.25rem) !important;
    line-height: 1.08 !important;
    max-width: 1100px !important;
}

.page-id-666 .duplex-about-cards .wp-block-group {
    padding: clamp(34px, 3.4vw, 48px) !important;
}

.page-id-666 .duplex-about-cards h3 {
    font-size: clamp(1.38rem, 2.2vw, 1.8rem) !important;
}

.page-id-666 .duplex-about-cards p {
    font-size: clamp(0.95rem, 1.05vw, 1.05rem) !important;
    line-height: 1.62 !important;
}

.page-id-666 .duplex-about-founder-card .wp-block-group {
    padding: clamp(38px, 3.6vw, 56px) !important;
}

.page-id-666 .duplex-about-founder-card h3 {
    font-size: clamp(1.8rem, 3vw, 2.45rem) !important;
}

.page-id-672 .duplex-v2-hero > .wp-block-group,
.page-id-673 .duplex-v2-hero > .wp-block-group {
    max-width: 1320px !important;
    padding-top: clamp(44px, 5vw, 68px) !important;
    padding-bottom: clamp(28px, 3.8vw, 44px) !important;
}

.page-id-672 .duplex-v2-hero .wp-block-heading,
.page-id-673 .duplex-v2-hero .wp-block-heading {
    font-size: clamp(3.1rem, 6.2vw, 5.8rem) !important;
}

.page-id-672 .duplex-v2-hero .wp-block-paragraph,
.page-id-673 .duplex-v2-hero .wp-block-paragraph {
    max-width: 980px !important;
    line-height: 1.48 !important;
}

.page-id-672 .duplex-services-full-grid,
.page-id-673 .duplex-press-grid {
    display: grid !important;
    gap: 1px !important;
    background: rgba(0, 0, 0, 0.08) !important;
    border: 0 !important;
}

.page-id-672 .duplex-services-full-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}

.page-id-673 .duplex-press-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}

.page-id-672 .service-full-card,
.page-id-673 .press-card-v10 {
    background: #fff !important;
    padding: clamp(30px, 3vw, 44px) !important;
}

.page-id-672 .service-full-card p,
.page-id-673 .press-card-v10 p {
    font-size: clamp(0.98rem, 1.08vw, 1.08rem) !important;
    line-height: 1.65 !important;
    color: rgba(17, 17, 17, 0.72) !important;
}

.page-id-672 .service-full-card .duplex-service-link,
.page-id-673 .press-card-v10 .duplex-press-link {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    margin-top: 22px;
    font-family: "Roboto Mono", monospace;
    font-size: 11px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    text-decoration: none;
    color: #111;
    border-bottom: 1px solid rgba(255, 107, 53, 0.45);
    padding-bottom: 4px;
}

.page-id-672 .service-full-card .duplex-service-link:hover,
.page-id-673 .press-card-v10 .duplex-press-link:hover {
    color: #ff6b35 !important;
    border-bottom-color: #ff6b35 !important;
}

.page-id-674 .duplex-v2-contact-columns {
    margin-top: 26px !important;
    padding-top: 8px !important;
    padding-bottom: 136px !important;
    column-gap: clamp(40px, 4.8vw, 72px) !important;
}

.page-id-674 .duplex-v2-contact-columns > .wp-block-column:first-child .wp-block-group {
    padding-top: 14px !important;
}

.page-id-674 .duplex-v2-contact-columns > .wp-block-column:last-child {
    padding-top: 12px !important;
}

.page-id-674 .duplex-contact-heading-note-20260601 {
    color: #ff6b35 !important;
}

.page-id-674 .forminator-ui .forminator-row {
    margin-bottom: 22px !important;
}

.page-id-674 .forminator-ui label {
    font-family: "Roboto Mono", monospace;
    font-size: 11px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #111 !important;
}

.page-id-674 .forminator-ui input:not([type="submit"]),
.page-id-674 .forminator-ui textarea,
.page-id-674 .forminator-ui select {
    border: 1px solid rgba(0, 0, 0, 0.32) !important;
    background: #fff !important;
    color: #111 !important;
    font-family: "Open Sans", sans-serif;
    font-size: 18px !important;
    padding: 16px 18px !important;
    min-height: 56px !important;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.page-id-674 .forminator-ui textarea {
    min-height: 170px !important;
    line-height: 1.5 !important;
}

.page-id-674 .forminator-ui input:focus,
.page-id-674 .forminator-ui textarea:focus,
.page-id-674 .forminator-ui select:focus {
    border-color: #ff6b35 !important;
    box-shadow: 0 0 0 2px rgba(255, 107, 53, 0.15) !important;
    outline: none !important;
}

.page-id-674 .forminator-ui .forminator-button-submit {
    background: #111 !important;
    color: #fff !important;
    border: 1px solid #111 !important;
    padding: 14px 26px !important;
    min-width: 190px;
    justify-content: center;
    display: inline-flex;
    align-items: center;
    font-family: "Roboto Mono", monospace;
    font-size: 11px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.page-id-674 .forminator-ui .forminator-button-submit:hover {
    background: #ff6b35 !important;
    border-color: #ff6b35 !important;
    color: #111 !important;
}

@media (max-width: 991px) {
    :root {
        --duplex-v2-shell-pad: 20px;
        --duplex-v2-hero-top: 44px;
        --duplex-v2-hero-bottom: 30px;
    }

    .page-id-666 .duplex-about-hero,
    .page-id-671 .duplex-v2-hero,
    .page-id-672 .duplex-v2-hero,
    .page-id-673 .duplex-v2-hero,
    .page-id-674 .duplex-v2-hero {
        padding-top: 12px !important;
    }

    .page-id-666 .duplex-about-hero > .wp-block-group,
    .page-id-671 .duplex-v2-hero > .wp-block-group,
    .page-id-672 .duplex-v2-hero > .wp-block-group,
    .page-id-673 .duplex-v2-hero > .wp-block-group,
    .page-id-674 .duplex-v2-hero > .wp-block-group {
        padding-top: 84px !important;
        padding-bottom: 44px !important;
    }

    .page-id-666 .duplex-about-shell,
    .page-id-666 .duplex-team-support,
    .page-id-666 .duplex-founder-grid,
    .page-id-666 .duplex-about-mission-grid,
    .page-id-672 .duplex-services-full-grid,
    .page-id-673 .duplex-press-grid {
        grid-template-columns: 1fr !important;
    }

    .page-id-674 .duplex-v2-contact-columns {
        margin-top: 10px !important;
        padding-top: 10px !important;
        row-gap: 48px !important;
    }
}

/* ==============================================================================
   📄 DUPLEX V2 CANONICAL TRANSITIONS & ANIMATIONS (Antigravity additions)
   ============================================================================== */
.duplex-v2-shell .duplex-project-card-v10,
.duplex-v2-shell .service-full-card,
.duplex-v2-shell .press-card-v10 {
    transition: transform 0.45s cubic-bezier(0.16, 1, 0.3, 1), box-shadow 0.45s ease !important;
    position: relative !important;
    overflow: hidden !important;
}

.duplex-v2-shell .duplex-project-card-v10:hover,
.duplex-v2-shell .service-full-card:hover,
.duplex-v2-shell .press-card-v10:hover {
    transform: translateY(-8px) !important;
    box-shadow: 0 32px 64px rgba(0, 0, 0, 0.08) !important;
}

/* Corner Orange Accent */
.duplex-v2-shell .duplex-project-card-v10::after {
    content: "";
    position: absolute;
    top: -24px;
    right: -24px;
    width: 48px;
    height: 48px;
    background: #FF6B35;
    transform: rotate(45deg);
    transition: transform 0.45s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.35s ease;
    opacity: 0;
    pointer-events: none;
    z-index: 10;
}

.duplex-v2-shell .duplex-project-card-v10:hover::after {
    opacity: 1;
    transform: rotate(45deg) scale(1.1);
}

/* Image Scale transitions */
.duplex-v2-shell .duplex-project-card-v10 img,
.duplex-v2-shell .service-full-card img,
.duplex-v2-shell .press-card-v10 img {
    transition: transform 0.7s cubic-bezier(0.16, 1, 0.3, 1), filter 0.7s ease !important;
}

.duplex-v2-shell .duplex-project-card-v10:hover img,
.duplex-v2-shell .service-full-card:hover img,
.duplex-v2-shell .press-card-v10:hover img {
    transform: scale(1.08) !important;
    filter: grayscale(0%) !important;
}

/* Serviços V2 Full Card Grid styling matching Sobre Nós */
.duplex-v2-shell .service-full-card .s-title {
    font-family: 'Montserrat', sans-serif !important;
    font-weight: 200 !important;
    font-size: clamp(1.8rem, 3.2vw, 2.5rem) !important;
    text-transform: uppercase !important;
    margin-bottom: 20px !important;
    letter-spacing: -0.02em !important;
    transition: color 0.35s ease !important;
}

.duplex-v2-shell .service-full-card:hover .s-title {
    color: #FF6B35 !important;
}

.duplex-v2-shell .service-full-card p {
    font-family: 'Open Sans', sans-serif !important;
    font-weight: 300 !important;
    font-size: 15px !important;
    color: rgba(17, 17, 17, 0.65) !important;
    line-height: 1.7 !important;
}

/* ==============================================================================
   INTERNAL PAGE TITLE RECOVERY
   Preserve the title hierarchy used by the current About/Projects page content.
   ============================================================================== */
.page-id-666 .duplex-about-intro {
    max-width: 760px;
    font-size: clamp(1.2rem, 1.75vw, 1.9rem) !important;
    line-height: 1.55 !important;
    color: rgba(17, 17, 17, 0.62) !important;
}

.page-id-666 .duplex-about-redesign {
    margin: 0 auto;
    padding: clamp(72px, 7vw, 110px) clamp(22px, 4vw, 56px);
}

.page-id-666 .duplex-about-shell {
    display: grid;
    grid-template-columns: minmax(120px, 170px) minmax(0, 1fr);
    gap: clamp(28px, 4vw, 52px);
    align-items: start;
}

.page-id-666 .duplex-about-kicker {
    margin: 0;
    font-family: var(--wp--preset--font-family--mono, 'Roboto Mono', monospace);
    font-size: 11px;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    color: #ff6b35;
}

.page-id-666 .duplex-about-stack > * + * {
    margin-top: 22px;
}

.page-id-666 .duplex-about-stack h2 {
    margin: 0;
    font-family: var(--wp--preset--font-family--heading, 'Montserrat', sans-serif);
    font-weight: 200;
    font-size: clamp(2.2rem, 4.7vw, 3.7rem);
    line-height: 1.02;
    color: inherit;
    text-transform: uppercase;
    letter-spacing: -0.025em;
}

.page-id-666 .duplex-about-lead {
    max-width: 860px;
    font-size: clamp(1rem, 1.15vw, 1.12rem);
    line-height: 1.75;
}

.page-id-666 .duplex-about-mission-v3 {
    background: #050505;
    color: #ffffff;
}

.page-id-666 .duplex-about-stack .duplex-about-lead {
    color: rgba(255, 255, 255, 0.78);
}

.page-id-666 .duplex-about-mission-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
    margin-top: 34px;
}

.page-id-666 .duplex-about-mission-card {
    background: linear-gradient(180deg, rgba(255,255,255,0.04) 0%, rgba(255,255,255,0.02) 100%);
    border: 1px solid rgba(255,255,255,0.08);
    min-height: 220px;
    padding: 30px 28px 28px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.page-id-666 .duplex-about-mission-card h3 {
    margin: 0 0 16px;
    font-family: var(--wp--preset--font-family--heading, 'Montserrat', sans-serif);
    font-size: clamp(1.3rem, 2vw, 1.7rem);
    font-weight: 300;
    letter-spacing: 0.01em;
    text-transform: uppercase;
    color: #ffffff;
}

.page-id-666 .duplex-about-mission-card p {
    margin: 0;
    color: rgba(255,255,255,0.74);
    font-size: 15px;
    line-height: 1.7;
}

.page-id-666 .duplex-about-team-v3 {
    background: linear-gradient(180deg, #f6f1ed 0%, #ffffff 34%);
    color: #111111;
}

.page-id-666 .duplex-about-team-v3 .duplex-about-stack h2 {
    color: #111111;
    text-transform: none;
}

.page-id-666 .duplex-about-team-v3 .duplex-about-stack .duplex-about-lead {
    color: rgba(17,17,17,0.66);
    max-width: 900px;
}

.page-id-666 .duplex-founder-grid {
    display: grid;
    grid-template-columns: minmax(0, 980px);
    justify-content: center;
    gap: 24px;
    margin-top: 34px;
}

.page-id-666 .duplex-founder-card {
    background: rgba(255,255,255,0.82);
    border: 1px solid rgba(17,17,17,0.08);
    padding: 34px 32px 30px;
    box-shadow: 0 20px 60px rgba(17,17,17,0.06);
}

.page-id-666 .duplex-founder-role {
    display: inline-block;
    margin: 0 0 14px;
    font-family: var(--wp--preset--font-family--mono, 'Roboto Mono', monospace);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: #ff6b35;
}

.page-id-666 .duplex-founder-card h3 {
    margin: 0 0 8px;
    font-family: var(--wp--preset--font-family--heading, 'Montserrat', sans-serif);
    font-size: clamp(1.65rem, 2.4vw, 2.3rem);
    font-weight: 300;
    color: #111111;
}

.page-id-666 .duplex-founder-card h4 {
    margin: 0 0 18px;
    font-size: 14px;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: rgba(17,17,17,0.46);
}

.page-id-666 .duplex-founder-card p {
    margin: 0;
    color: rgba(17,17,17,0.72);
    font-size: 15px;
    line-height: 1.75;
}

.page-id-666 .duplex-founder-card p + p {
    margin-top: 12px;
}

.page-id-666 .duplex-team-photo-slot {
    margin-top: clamp(22px, 3vw, 34px);
    max-width: 980px;
    margin-left: auto;
    margin-right: auto;
    border: 1px solid rgba(17,17,17,0.08);
    background: #ffffff;
    padding: clamp(18px, 2vw, 24px);
}

.page-id-666 .duplex-team-photo-slot figure {
    margin: 0;
}

.page-id-666 .duplex-team-photo-slot img {
    display: block;
    width: 100%;
    height: auto;
}

.page-id-666 .duplex-team-photo-caption {
    margin: 14px 0 0;
    font-family: var(--wp--preset--font-family--mono, 'Roboto Mono', monospace);
    font-size: 10px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: rgba(17,17,17,0.46);
}

.page-id-666 .duplex-team-support {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(280px, 0.9fr);
    gap: 2px;
    margin-top: 26px;
    max-width: 980px;
    margin-left: auto;
    margin-right: auto;
}

.page-id-666 .duplex-team-support-copy,
.page-id-666 .duplex-team-roster {
    background: #ffffff;
    border: 1px solid rgba(17,17,17,0.08);
    padding: 28px 30px;
}

.page-id-666 .duplex-team-support-copy h3,
.page-id-666 .duplex-team-roster h3 {
    margin: 0 0 12px;
    font-family: var(--wp--preset--font-family--heading, 'Montserrat', sans-serif);
    font-size: clamp(1.2rem, 1.7vw, 1.5rem);
    font-weight: 300;
    text-transform: uppercase;
    color: #111111;
}

.page-id-666 .duplex-team-support-copy p,
.page-id-666 .duplex-team-roster p {
    margin: 0;
    color: rgba(17,17,17,0.68);
    font-size: 15px;
    line-height: 1.75;
}

.page-id-666 .duplex-team-roster ul {
    margin: 16px 0 0;
    padding-left: 20px;
    color: rgba(17,17,17,0.78);
}

.page-id-666 .duplex-team-roster li {
    margin: 0 0 10px;
    line-height: 1.7;
}

@media (max-width: 991px) {
    .page-id-666 .duplex-about-shell,
    .page-id-666 .duplex-team-support,
    .page-id-666 .duplex-founder-grid,
    .page-id-666 .duplex-about-mission-grid {
        grid-template-columns: 1fr;
    }

    .page-id-666 .duplex-about-redesign {
        padding: 56px 22px;
    }

    .page-id-666 .duplex-founder-card,
    .page-id-666 .duplex-team-support-copy,
    .page-id-666 .duplex-team-roster,
    .page-id-666 .duplex-about-mission-card {
        padding: 24px 22px;
    }

    .page-id-666 .duplex-founder-grid,
    .page-id-666 .duplex-team-photo-slot,
    .page-id-666 .duplex-team-support {
        max-width: 100%;
        margin-left: 0;
        margin-right: 0;
    }
}

/* ==============================================================================
   INTERNAL V2 CANONICAL LAYOUT RECOVERY
   Final authoritative layer for the currently public internal pages.
   ============================================================================== */
.page-id-666 .duplex-about-hero,
.page-id-671 .duplex-v2-hero,
.page-id-672 .duplex-v2-hero,
.page-id-673 .duplex-v2-hero,
.page-id-674 .duplex-v2-hero {
    padding-top: 0 !important;
    border-top: 1px solid rgba(0, 0, 0, 0.05) !important;
}

.page-id-666 .duplex-about-hero > .wp-block-group,
.page-id-671 .duplex-v2-hero > .wp-block-group,
.page-id-672 .duplex-v2-hero > .wp-block-group,
.page-id-673 .duplex-v2-hero > .wp-block-group,
.page-id-674 .duplex-v2-hero > .wp-block-group {
    max-width: 1360px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-top: clamp(108px, 10vw, 156px) !important;
    padding-bottom: clamp(54px, 5vw, 82px) !important;
    padding-left: clamp(22px, 4vw, 56px) !important;
    padding-right: clamp(22px, 4vw, 56px) !important;
    text-align: center !important;
    justify-content: center !important;
}

.page-id-666 .duplex-about-hero .wp-block-heading,
.page-id-671 .duplex-v2-hero .wp-block-heading,
.page-id-672 .duplex-v2-hero .wp-block-heading,
.page-id-673 .duplex-v2-hero .wp-block-heading,
.page-id-674 .duplex-v2-hero .wp-block-heading {
    margin: 0 auto 18px !important;
    max-width: 1100px !important;
    font-size: clamp(3.5rem, 8vw, 6.4rem) !important;
    line-height: 0.92 !important;
    letter-spacing: -0.04em !important;
    text-align: center !important;
}

.page-id-666 .duplex-about-hero > .wp-block-group > .wp-block-paragraph:first-of-type,
.page-id-671 .duplex-v2-hero > .wp-block-group > .wp-block-paragraph:first-of-type,
.page-id-672 .duplex-v2-hero > .wp-block-group > .wp-block-paragraph:first-of-type,
.page-id-673 .duplex-v2-hero > .wp-block-group > .wp-block-paragraph:first-of-type,
.page-id-674 .duplex-v2-hero > .wp-block-group > .wp-block-paragraph:first-of-type {
    color: #ff6b35 !important;
    font-family: "Roboto Mono", monospace !important;
    font-size: 10px !important;
    font-weight: 500 !important;
    letter-spacing: 0.3em !important;
    text-transform: uppercase !important;
    margin: 0 auto 24px !important;
    line-height: 1.2 !important;
}

.page-id-666 .duplex-about-hero .wp-block-paragraph,
.page-id-671 .duplex-v2-hero .wp-block-paragraph,
.page-id-672 .duplex-v2-hero .wp-block-paragraph,
.page-id-673 .duplex-v2-hero .wp-block-paragraph,
.page-id-674 .duplex-v2-hero .wp-block-paragraph {
    max-width: 980px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    text-align: center !important;
}

.page-id-666 .duplex-about-hero .wp-block-paragraph:not(.duplex-about-intro),
.page-id-671 .duplex-v2-hero .wp-block-paragraph,
.page-id-672 .duplex-v2-hero .wp-block-paragraph,
.page-id-673 .duplex-v2-hero .wp-block-paragraph,
.page-id-674 .duplex-v2-hero .wp-block-paragraph {
    font-size: clamp(1.18rem, 1.7vw, 1.72rem) !important;
    line-height: 1.55 !important;
    color: rgba(17, 17, 17, 0.58) !important;
}

.page-id-671 .duplex-v2-shell,
.page-id-672 .duplex-v2-shell,
.page-id-673 .duplex-v2-shell,
.page-id-674 .duplex-v2-contact-columns {
    padding-top: clamp(12px, 2vw, 26px) !important;
}

.page-id-671 .duplex-filter-v10-container,
.page-id-672 .duplex-filter-v10-container,
.page-id-673 .duplex-filter-v10-container {
    margin-top: 0 !important;
    margin-bottom: clamp(34px, 4vw, 46px) !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    border-bottom: 0 !important;
    position: relative !important;
    top: auto !important;
    background: transparent !important;
}

.page-id-671 .duplex-filter-v10-scroll,
.page-id-672 .duplex-filter-v10-scroll,
.page-id-673 .duplex-filter-v10-scroll {
    flex-wrap: wrap !important;
    justify-content: center !important;
    gap: 10px !important;
}

.page-id-671 .filter-tab-v10,
.page-id-672 .filter-tab-v10,
.page-id-673 .filter-tab-v10 {
    padding: 10px 18px !important;
    min-height: 42px !important;
    border-radius: 999px !important;
    font-size: 10px !important;
    font-weight: 500 !important;
    letter-spacing: 0.18em !important;
    color: rgba(17, 17, 17, 0.52) !important;
    border: 1px solid rgba(17, 17, 17, 0.09) !important;
    box-shadow: none !important;
}

.page-id-671 .filter-tab-v10:hover,
.page-id-672 .filter-tab-v10:hover,
.page-id-673 .filter-tab-v10:hover {
    color: #ff6b35 !important;
    border-color: rgba(255, 107, 53, 0.36) !important;
    background: #fff !important;
}

.page-id-671 .filter-tab-v10.active,
.page-id-672 .filter-tab-v10.active,
.page-id-673 .filter-tab-v10.active {
    background: #111 !important;
    color: #fff !important;
    border-color: #111 !important;
}

.page-id-671 .duplex-projects-container,
.page-id-672 .duplex-services-full-grid,
.page-id-673 .duplex-press-grid {
    max-width: 1360px !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

.page-id-672 .duplex-services-full-grid,
.page-id-673 .duplex-press-grid {
    margin-top: clamp(12px, 2vw, 24px) !important;
}

.page-id-672 .service-full-card,
.page-id-673 .press-card-v10 {
    min-height: 100% !important;
}

.page-id-672 .service-full-card .duplex-service-link,
.page-id-673 .press-card-v10 .duplex-press-link {
    display: inline-flex !important;
    align-items: center !important;
    gap: 10px !important;
    margin-top: 24px !important;
    font-family: "Roboto Mono", monospace !important;
    font-size: 11px !important;
    letter-spacing: 0.16em !important;
    text-transform: uppercase !important;
    text-decoration: none !important;
    color: #111 !important;
    border-bottom: 1px solid rgba(255, 107, 53, 0.42) !important;
    padding-bottom: 4px !important;
    transition: color 0.25s ease, border-color 0.25s ease, gap 0.25s ease !important;
}

.page-id-674 .duplex-v2-contact-columns {
    max-width: 1360px !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

@media (max-width: 991px) {
    .page-id-666 .duplex-about-hero > .wp-block-group,
    .page-id-671 .duplex-v2-hero > .wp-block-group,
    .page-id-672 .duplex-v2-hero > .wp-block-group,
    .page-id-673 .duplex-v2-hero > .wp-block-group,
    .page-id-674 .duplex-v2-hero > .wp-block-group {
        padding-top: 84px !important;
        padding-bottom: 42px !important;
    }

    .page-id-666 .duplex-about-hero .wp-block-heading,
    .page-id-671 .duplex-v2-hero .wp-block-heading,
    .page-id-672 .duplex-v2-hero .wp-block-heading,
    .page-id-673 .duplex-v2-hero .wp-block-heading,
    .page-id-674 .duplex-v2-hero .wp-block-heading {
        font-size: clamp(2.7rem, 12vw, 4.2rem) !important;
        line-height: 0.98 !important;
    }
}
