Updated
November 15, 2023
LnRiLWhlYWRpbmcuaGFzLWJhY2tncm91bmR7cGFkZGluZzowfQ==
.tb-image{position:relative;transition:transform 0.25s ease}.wp-block-image .tb-image.aligncenter{margin-left:auto;margin-right:auto}.tb-image img{max-width:100%;height:auto;width:auto;transition:transform 0.25s ease}.tb-image .tb-image-caption-fit-to-image{display:table}.tb-image .tb-image-caption-fit-to-image .tb-image-caption{display:table-caption;caption-side:bottom} .tb-image[data-toolset-blocks-image="806ff60c5afaa915c244acdfde418b7c"] { max-width: 100%; } .tb-image[data-toolset-blocks-image="806ff60c5afaa915c244acdfde418b7c"] img { border: 1px solid rgba( 222, 222, 222, 1 ); } .tb-image{position:relative;transition:transform 0.25s ease}.wp-block-image .tb-image.aligncenter{margin-left:auto;margin-right:auto}.tb-image img{max-width:100%;height:auto;width:auto;transition:transform 0.25s ease}.tb-image .tb-image-caption-fit-to-image{display:table}.tb-image .tb-image-caption-fit-to-image .tb-image-caption{display:table-caption;caption-side:bottom} .tb-image[data-toolset-blocks-image="1344470cc2feb34aaeb1f710a70134b3"] { max-width: 100%; } .tb-image[data-toolset-blocks-image="1344470cc2feb34aaeb1f710a70134b3"] img { border: 1px solid rgba( 222, 222, 222, 1 ); } .tb-image{position:relative;transition:transform 0.25s ease}.wp-block-image .tb-image.aligncenter{margin-left:auto;margin-right:auto}.tb-image img{max-width:100%;height:auto;width:auto;transition:transform 0.25s ease}.tb-image .tb-image-caption-fit-to-image{display:table}.tb-image .tb-image-caption-fit-to-image .tb-image-caption{display:table-caption;caption-side:bottom} .tb-image[data-toolset-blocks-image="0ca28487f92913cb3318b30d7a3529ea"] { max-width: 100%; } .tb-image[data-toolset-blocks-image="0ca28487f92913cb3318b30d7a3529ea"] img { border: 1px solid rgba( 222, 222, 222, 1 ); } .tb-image{position:relative;transition:transform 0.25s ease}.wp-block-image .tb-image.aligncenter{margin-left:auto;margin-right:auto}.tb-image img{max-width:100%;height:auto;width:auto;transition:transform 0.25s ease}.tb-image .tb-image-caption-fit-to-image{display:table}.tb-image .tb-image-caption-fit-to-image .tb-image-caption{display:table-caption;caption-side:bottom} .tb-image[data-toolset-blocks-image="aaae033d71c4589915c8513bd39b10f4"] { max-width: 100%; } .tb-image[data-toolset-blocks-image="aaae033d71c4589915c8513bd39b10f4"] img { border: 1px solid rgba( 222, 222, 222, 1 ); } .tb-image{position:relative;transition:transform 0.25s ease}.wp-block-image .tb-image.aligncenter{margin-left:auto;margin-right:auto}.tb-image img{max-width:100%;height:auto;width:auto;transition:transform 0.25s ease}.tb-image .tb-image-caption-fit-to-image{display:table}.tb-image .tb-image-caption-fit-to-image .tb-image-caption{display:table-caption;caption-side:bottom} .tb-image[data-toolset-blocks-image="45574f587232765caf3e0ec5623c2400"] { max-width: 100%; } .tb-image[data-toolset-blocks-image="45574f587232765caf3e0ec5623c2400"] img { border: 1px solid rgba( 222, 222, 222, 1 ); } .tb-image{position:relative;transition:transform 0.25s ease}.wp-block-image .tb-image.aligncenter{margin-left:auto;margin-right:auto}.tb-image img{max-width:100%;height:auto;width:auto;transition:transform 0.25s ease}.tb-image .tb-image-caption-fit-to-image{display:table}.tb-image .tb-image-caption-fit-to-image .tb-image-caption{display:table-caption;caption-side:bottom} .tb-image[data-toolset-blocks-image="d8cd6483c5526afa95024128617be7b2"] { max-width: 100%; } .tb-image[data-toolset-blocks-image="d8cd6483c5526afa95024128617be7b2"] img { border: 1px solid rgba( 222, 222, 222, 1 ); } .tb-image{position:relative;transition:transform 0.25s ease}.wp-block-image .tb-image.aligncenter{margin-left:auto;margin-right:auto}.tb-image img{max-width:100%;height:auto;width:auto;transition:transform 0.25s ease}.tb-image .tb-image-caption-fit-to-image{display:table}.tb-image .tb-image-caption-fit-to-image .tb-image-caption{display:table-caption;caption-side:bottom} .tb-image[data-toolset-blocks-image="b361925a6463a22fbfe4fcff1609c1e8"] { max-width: 100%; } .tb-image[data-toolset-blocks-image="b361925a6463a22fbfe4fcff1609c1e8"] img { border: 1px solid rgba( 222, 222, 222, 1 ); } .tb-image{position:relative;transition:transform 0.25s ease}.wp-block-image .tb-image.aligncenter{margin-left:auto;margin-right:auto}.tb-image img{max-width:100%;height:auto;width:auto;transition:transform 0.25s ease}.tb-image .tb-image-caption-fit-to-image{display:table}.tb-image .tb-image-caption-fit-to-image .tb-image-caption{display:table-caption;caption-side:bottom} .tb-image[data-toolset-blocks-image="bf5f2062b84d2f27086e3c428908b34a"] { max-width: 100%; } .tb-image[data-toolset-blocks-image="bf5f2062b84d2f27086e3c428908b34a"] img { border: 1px solid rgba( 222, 222, 222, 1 ); } .tb-image{position:relative;transition:transform 0.25s ease}.wp-block-image .tb-image.aligncenter{margin-left:auto;margin-right:auto}.tb-image img{max-width:100%;height:auto;width:auto;transition:transform 0.25s ease}.tb-image .tb-image-caption-fit-to-image{display:table}.tb-image .tb-image-caption-fit-to-image .tb-image-caption{display:table-caption;caption-side:bottom} .tb-image[data-toolset-blocks-image="a8b72c2d7b4dd01af7954520a8156867"] { max-width: 100%; } .tb-image[data-toolset-blocks-image="a8b72c2d7b4dd01af7954520a8156867"] img { border: 1px solid rgba( 222, 222, 222, 1 ); } .tb-image{position:relative;transition:transform 0.25s ease}.wp-block-image .tb-image.aligncenter{margin-left:auto;margin-right:auto}.tb-image img{max-width:100%;height:auto;width:auto;transition:transform 0.25s ease}.tb-image .tb-image-caption-fit-to-image{display:table}.tb-image .tb-image-caption-fit-to-image .tb-image-caption{display:table-caption;caption-side:bottom} .tb-image[data-toolset-blocks-image="d4556bccffb0d8ec04cc4643b0532458"] { max-width: 100%; } .tb-image[data-toolset-blocks-image="d4556bccffb0d8ec04cc4643b0532458"] img { border: 1px solid rgba( 222, 222, 222, 1 ); } .tb-container .tb-container-inner{width:100%;margin:0 auto} .wp-block-toolset-blocks-container.tb-container[data-toolset-blocks-container="7c032029a6dd00d67016e81b04441a49"] { padding: 25px; } .tb-container .tb-container-inner{width:100%;margin:0 auto} .wp-block-toolset-blocks-container.tb-container[data-toolset-blocks-container="bff7c4bf6aee0775a46d14d80a2a5154"] { border-radius: 5px;background-image:linear-gradient( -90deg,rgba( 215, 95, 43, 1 ),rgba( 255, 97, 97, 1 ) );padding: 25px;border: 0px solid rgba( 0, 0, 0, 1 ); } .tb-button{color:#f1f1f1}.tb-button--left{text-align:left}.tb-button--center{text-align:center}.tb-button--right{text-align:right}.tb-button__link{color:inherit;cursor:pointer;display:inline-block;line-height:100%;text-decoration:none !important;text-align:center;transition:all 0.3s ease}.tb-button__link:hover,.tb-button__link:focus,.tb-button__link:visited{color:inherit}.tb-button__link:hover .tb-button__content,.tb-button__link:focus .tb-button__content,.tb-button__link:visited .tb-button__content{font-family:inherit;font-style:inherit;font-weight:inherit;letter-spacing:inherit;text-decoration:inherit;text-shadow:inherit;text-transform:inherit}.tb-button__content{vertical-align:middle;transition:all 0.3s ease}.tb-button__icon{transition:all 0.3s ease;display:inline-block;vertical-align:middle;font-style:normal !important}.tb-button__icon::before{content:attr(data-font-code);font-weight:normal !important}.tb-button__link{background-color:#444;border-radius:0.3em;font-size:1.3em;margin-bottom:0.76em;padding:0.55em 1.5em 0.55em} .tb-button[data-toolset-blocks-button="ba39db5e1d580d13c8b29c52ed79492c"] { text-align: center; } .tb-button[data-toolset-blocks-button="ba39db5e1d580d13c8b29c52ed79492c"] .tb-button__link { background-color: rgba( 55, 55, 55, 1 );border-radius: 5px;color: rgba( 255, 255, 255, 1 );padding-top: 15px;padding-bottom: 15px;margin-top: 20px;font-size: 15px;color: rgba( 255, 255, 255, 1 ); } .tb-heading[data-toolset-blocks-heading="694a23e76bbed8a582cba424c2e46d39"]  { color: rgba( 255, 255, 255, 1 );text-align: center; }  h2.tb-heading[data-toolset-blocks-heading="435de35c87638528ed9780c2c3190f83"]  { color: rgba( 255, 255, 255, 1 );text-align: center;padding-top: 0px;margin-top: 0px; }  .tb-image{position:relative;transition:transform 0.25s ease}.wp-block-image .tb-image.aligncenter{margin-left:auto;margin-right:auto}.tb-image img{max-width:100%;height:auto;width:auto;transition:transform 0.25s ease}.tb-image .tb-image-caption-fit-to-image{display:table}.tb-image .tb-image-caption-fit-to-image .tb-image-caption{display:table-caption;caption-side:bottom} .tb-image[data-toolset-blocks-image="558c61349b5c5b1e61d3ac8efcf849d3"] { max-width: 100%; } .tb-image[data-toolset-blocks-image="558c61349b5c5b1e61d3ac8efcf849d3"] img { padding-bottom: 0px;margin-bottom: 0px; } .tb-grid,.tb-grid>.block-editor-inner-blocks>.block-editor-block-list__layout{display:grid;grid-row-gap:25px;grid-column-gap:25px}.tb-grid-item{background:#d38a03;padding:30px}.tb-grid-column{flex-wrap:wrap}.tb-grid-column>*{width:100%}.tb-grid-column.tb-grid-align-top{width:100%;display:flex;align-content:flex-start}.tb-grid-column.tb-grid-align-center{width:100%;display:flex;align-content:center}.tb-grid-column.tb-grid-align-bottom{width:100%;display:flex;align-content:flex-end} .wp-block-toolset-blocks-grid.tb-grid[data-toolset-blocks-grid="ac5a9b338e066a035374a7c135358093"] { grid-template-columns: minmax(0, 0.32fr) minmax(0, 0.68fr);grid-auto-flow: row } .wp-block-toolset-blocks-grid.tb-grid[data-toolset-blocks-grid="ac5a9b338e066a035374a7c135358093"] > .tb-grid-column:nth-of-type(2n + 1) { grid-column: 1 } .wp-block-toolset-blocks-grid.tb-grid[data-toolset-blocks-grid="ac5a9b338e066a035374a7c135358093"] > .tb-grid-column:nth-of-type(2n + 2) { grid-column: 2 } .wp-block-toolset-blocks-grid-column.tb-grid-column[data-toolset-blocks-grid-column="3034fbe886c11054e95b46b09d3e4112"] { display: flex; } .tb-image{position:relative;transition:transform 0.25s ease}.wp-block-image .tb-image.aligncenter{margin-left:auto;margin-right:auto}.tb-image img{max-width:100%;height:auto;width:auto;transition:transform 0.25s ease}.tb-image .tb-image-caption-fit-to-image{display:table}.tb-image .tb-image-caption-fit-to-image .tb-image-caption{display:table-caption;caption-side:bottom} .wp-block-image.tb-image[data-toolset-blocks-image="859afff8b33cd240c1bef10105c926e0"] { max-width: 100%; } @media only screen and (max-width: 781px) { .tb-image{position:relative;transition:transform 0.25s ease}.wp-block-image .tb-image.aligncenter{margin-left:auto;margin-right:auto}.tb-image img{max-width:100%;height:auto;width:auto;transition:transform 0.25s ease}.tb-image .tb-image-caption-fit-to-image{display:table}.tb-image .tb-image-caption-fit-to-image .tb-image-caption{display:table-caption;caption-side:bottom}.tb-image{position:relative;transition:transform 0.25s ease}.wp-block-image .tb-image.aligncenter{margin-left:auto;margin-right:auto}.tb-image img{max-width:100%;height:auto;width:auto;transition:transform 0.25s ease}.tb-image .tb-image-caption-fit-to-image{display:table}.tb-image .tb-image-caption-fit-to-image .tb-image-caption{display:table-caption;caption-side:bottom}.tb-image{position:relative;transition:transform 0.25s ease}.wp-block-image .tb-image.aligncenter{margin-left:auto;margin-right:auto}.tb-image img{max-width:100%;height:auto;width:auto;transition:transform 0.25s ease}.tb-image .tb-image-caption-fit-to-image{display:table}.tb-image .tb-image-caption-fit-to-image .tb-image-caption{display:table-caption;caption-side:bottom}.tb-image{position:relative;transition:transform 0.25s ease}.wp-block-image .tb-image.aligncenter{margin-left:auto;margin-right:auto}.tb-image img{max-width:100%;height:auto;width:auto;transition:transform 0.25s ease}.tb-image .tb-image-caption-fit-to-image{display:table}.tb-image .tb-image-caption-fit-to-image .tb-image-caption{display:table-caption;caption-side:bottom}.tb-image{position:relative;transition:transform 0.25s ease}.wp-block-image .tb-image.aligncenter{margin-left:auto;margin-right:auto}.tb-image img{max-width:100%;height:auto;width:auto;transition:transform 0.25s ease}.tb-image .tb-image-caption-fit-to-image{display:table}.tb-image .tb-image-caption-fit-to-image .tb-image-caption{display:table-caption;caption-side:bottom}.tb-image{position:relative;transition:transform 0.25s ease}.wp-block-image .tb-image.aligncenter{margin-left:auto;margin-right:auto}.tb-image img{max-width:100%;height:auto;width:auto;transition:transform 0.25s ease}.tb-image .tb-image-caption-fit-to-image{display:table}.tb-image .tb-image-caption-fit-to-image .tb-image-caption{display:table-caption;caption-side:bottom}.tb-image{position:relative;transition:transform 0.25s ease}.wp-block-image .tb-image.aligncenter{margin-left:auto;margin-right:auto}.tb-image img{max-width:100%;height:auto;width:auto;transition:transform 0.25s ease}.tb-image .tb-image-caption-fit-to-image{display:table}.tb-image .tb-image-caption-fit-to-image .tb-image-caption{display:table-caption;caption-side:bottom}.tb-image{position:relative;transition:transform 0.25s ease}.wp-block-image .tb-image.aligncenter{margin-left:auto;margin-right:auto}.tb-image img{max-width:100%;height:auto;width:auto;transition:transform 0.25s ease}.tb-image .tb-image-caption-fit-to-image{display:table}.tb-image .tb-image-caption-fit-to-image .tb-image-caption{display:table-caption;caption-side:bottom}.tb-image{position:relative;transition:transform 0.25s ease}.wp-block-image .tb-image.aligncenter{margin-left:auto;margin-right:auto}.tb-image img{max-width:100%;height:auto;width:auto;transition:transform 0.25s ease}.tb-image .tb-image-caption-fit-to-image{display:table}.tb-image .tb-image-caption-fit-to-image .tb-image-caption{display:table-caption;caption-side:bottom}.tb-image{position:relative;transition:transform 0.25s ease}.wp-block-image .tb-image.aligncenter{margin-left:auto;margin-right:auto}.tb-image img{max-width:100%;height:auto;width:auto;transition:transform 0.25s ease}.tb-image .tb-image-caption-fit-to-image{display:table}.tb-image .tb-image-caption-fit-to-image .tb-image-caption{display:table-caption;caption-side:bottom}.tb-container .tb-container-inner{width:100%;margin:0 auto}.tb-container .tb-container-inner{width:100%;margin:0 auto}.tb-button{color:#f1f1f1}.tb-button--left{text-align:left}.tb-button--center{text-align:center}.tb-button--right{text-align:right}.tb-button__link{color:inherit;cursor:pointer;display:inline-block;line-height:100%;text-decoration:none !important;text-align:center;transition:all 0.3s ease}.tb-button__link:hover,.tb-button__link:focus,.tb-button__link:visited{color:inherit}.tb-button__link:hover .tb-button__content,.tb-button__link:focus .tb-button__content,.tb-button__link:visited .tb-button__content{font-family:inherit;font-style:inherit;font-weight:inherit;letter-spacing:inherit;text-decoration:inherit;text-shadow:inherit;text-transform:inherit}.tb-button__content{vertical-align:middle;transition:all 0.3s ease}.tb-button__icon{transition:all 0.3s ease;display:inline-block;vertical-align:middle;font-style:normal !important}.tb-button__icon::before{content:attr(data-font-code);font-weight:normal !important}.tb-button__link{background-color:#444;border-radius:0.3em;font-size:1.3em;margin-bottom:0.76em;padding:0.55em 1.5em 0.55em}  .tb-image{position:relative;transition:transform 0.25s ease}.wp-block-image .tb-image.aligncenter{margin-left:auto;margin-right:auto}.tb-image img{max-width:100%;height:auto;width:auto;transition:transform 0.25s ease}.tb-image .tb-image-caption-fit-to-image{display:table}.tb-image .tb-image-caption-fit-to-image .tb-image-caption{display:table-caption;caption-side:bottom}.tb-grid,.tb-grid>.block-editor-inner-blocks>.block-editor-block-list__layout{display:grid;grid-row-gap:25px;grid-column-gap:25px}.tb-grid-item{background:#d38a03;padding:30px}.tb-grid-column{flex-wrap:wrap}.tb-grid-column>*{width:100%}.tb-grid-column.tb-grid-align-top{width:100%;display:flex;align-content:flex-start}.tb-grid-column.tb-grid-align-center{width:100%;display:flex;align-content:center}.tb-grid-column.tb-grid-align-bottom{width:100%;display:flex;align-content:flex-end} .wp-block-toolset-blocks-grid.tb-grid[data-toolset-blocks-grid="ac5a9b338e066a035374a7c135358093"] { grid-template-columns: minmax(0, 0.5fr) minmax(0, 0.5fr);grid-auto-flow: row } .wp-block-toolset-blocks-grid.tb-grid[data-toolset-blocks-grid="ac5a9b338e066a035374a7c135358093"] > .tb-grid-column:nth-of-type(2n + 1) { grid-column: 1 } .wp-block-toolset-blocks-grid.tb-grid[data-toolset-blocks-grid="ac5a9b338e066a035374a7c135358093"] > .tb-grid-column:nth-of-type(2n + 2) { grid-column: 2 } .wp-block-toolset-blocks-grid-column.tb-grid-column[data-toolset-blocks-grid-column="3034fbe886c11054e95b46b09d3e4112"] { display: flex; } .tb-image{position:relative;transition:transform 0.25s ease}.wp-block-image .tb-image.aligncenter{margin-left:auto;margin-right:auto}.tb-image img{max-width:100%;height:auto;width:auto;transition:transform 0.25s ease}.tb-image .tb-image-caption-fit-to-image{display:table}.tb-image .tb-image-caption-fit-to-image .tb-image-caption{display:table-caption;caption-side:bottom} } @media only screen and (max-width: 599px) { .tb-image{position:relative;transition:transform 0.25s ease}.wp-block-image .tb-image.aligncenter{margin-left:auto;margin-right:auto}.tb-image img{max-width:100%;height:auto;width:auto;transition:transform 0.25s ease}.tb-image .tb-image-caption-fit-to-image{display:table}.tb-image .tb-image-caption-fit-to-image .tb-image-caption{display:table-caption;caption-side:bottom}.tb-image{position:relative;transition:transform 0.25s ease}.wp-block-image .tb-image.aligncenter{margin-left:auto;margin-right:auto}.tb-image img{max-width:100%;height:auto;width:auto;transition:transform 0.25s ease}.tb-image .tb-image-caption-fit-to-image{display:table}.tb-image .tb-image-caption-fit-to-image .tb-image-caption{display:table-caption;caption-side:bottom}.tb-image{position:relative;transition:transform 0.25s ease}.wp-block-image .tb-image.aligncenter{margin-left:auto;margin-right:auto}.tb-image img{max-width:100%;height:auto;width:auto;transition:transform 0.25s ease}.tb-image .tb-image-caption-fit-to-image{display:table}.tb-image .tb-image-caption-fit-to-image .tb-image-caption{display:table-caption;caption-side:bottom}.tb-image{position:relative;transition:transform 0.25s ease}.wp-block-image .tb-image.aligncenter{margin-left:auto;margin-right:auto}.tb-image img{max-width:100%;height:auto;width:auto;transition:transform 0.25s ease}.tb-image .tb-image-caption-fit-to-image{display:table}.tb-image .tb-image-caption-fit-to-image .tb-image-caption{display:table-caption;caption-side:bottom}.tb-image{position:relative;transition:transform 0.25s ease}.wp-block-image .tb-image.aligncenter{margin-left:auto;margin-right:auto}.tb-image img{max-width:100%;height:auto;width:auto;transition:transform 0.25s ease}.tb-image .tb-image-caption-fit-to-image{display:table}.tb-image .tb-image-caption-fit-to-image .tb-image-caption{display:table-caption;caption-side:bottom}.tb-image{position:relative;transition:transform 0.25s ease}.wp-block-image .tb-image.aligncenter{margin-left:auto;margin-right:auto}.tb-image img{max-width:100%;height:auto;width:auto;transition:transform 0.25s ease}.tb-image .tb-image-caption-fit-to-image{display:table}.tb-image .tb-image-caption-fit-to-image .tb-image-caption{display:table-caption;caption-side:bottom}.tb-image{position:relative;transition:transform 0.25s ease}.wp-block-image .tb-image.aligncenter{margin-left:auto;margin-right:auto}.tb-image img{max-width:100%;height:auto;width:auto;transition:transform 0.25s ease}.tb-image .tb-image-caption-fit-to-image{display:table}.tb-image .tb-image-caption-fit-to-image .tb-image-caption{display:table-caption;caption-side:bottom}.tb-image{position:relative;transition:transform 0.25s ease}.wp-block-image .tb-image.aligncenter{margin-left:auto;margin-right:auto}.tb-image img{max-width:100%;height:auto;width:auto;transition:transform 0.25s ease}.tb-image .tb-image-caption-fit-to-image{display:table}.tb-image .tb-image-caption-fit-to-image .tb-image-caption{display:table-caption;caption-side:bottom}.tb-image{position:relative;transition:transform 0.25s ease}.wp-block-image .tb-image.aligncenter{margin-left:auto;margin-right:auto}.tb-image img{max-width:100%;height:auto;width:auto;transition:transform 0.25s ease}.tb-image .tb-image-caption-fit-to-image{display:table}.tb-image .tb-image-caption-fit-to-image .tb-image-caption{display:table-caption;caption-side:bottom}.tb-image{position:relative;transition:transform 0.25s ease}.wp-block-image .tb-image.aligncenter{margin-left:auto;margin-right:auto}.tb-image img{max-width:100%;height:auto;width:auto;transition:transform 0.25s ease}.tb-image .tb-image-caption-fit-to-image{display:table}.tb-image .tb-image-caption-fit-to-image .tb-image-caption{display:table-caption;caption-side:bottom}.tb-container .tb-container-inner{width:100%;margin:0 auto}.tb-container .tb-container-inner{width:100%;margin:0 auto}.tb-button{color:#f1f1f1}.tb-button--left{text-align:left}.tb-button--center{text-align:center}.tb-button--right{text-align:right}.tb-button__link{color:inherit;cursor:pointer;display:inline-block;line-height:100%;text-decoration:none !important;text-align:center;transition:all 0.3s ease}.tb-button__link:hover,.tb-button__link:focus,.tb-button__link:visited{color:inherit}.tb-button__link:hover .tb-button__content,.tb-button__link:focus .tb-button__content,.tb-button__link:visited .tb-button__content{font-family:inherit;font-style:inherit;font-weight:inherit;letter-spacing:inherit;text-decoration:inherit;text-shadow:inherit;text-transform:inherit}.tb-button__content{vertical-align:middle;transition:all 0.3s ease}.tb-button__icon{transition:all 0.3s ease;display:inline-block;vertical-align:middle;font-style:normal !important}.tb-button__icon::before{content:attr(data-font-code);font-weight:normal !important}.tb-button__link{background-color:#444;border-radius:0.3em;font-size:1.3em;margin-bottom:0.76em;padding:0.55em 1.5em 0.55em}  .tb-image{position:relative;transition:transform 0.25s ease}.wp-block-image .tb-image.aligncenter{margin-left:auto;margin-right:auto}.tb-image img{max-width:100%;height:auto;width:auto;transition:transform 0.25s ease}.tb-image .tb-image-caption-fit-to-image{display:table}.tb-image .tb-image-caption-fit-to-image .tb-image-caption{display:table-caption;caption-side:bottom}.tb-grid,.tb-grid>.block-editor-inner-blocks>.block-editor-block-list__layout{display:grid;grid-row-gap:25px;grid-column-gap:25px}.tb-grid-item{background:#d38a03;padding:30px}.tb-grid-column{flex-wrap:wrap}.tb-grid-column>*{width:100%}.tb-grid-column.tb-grid-align-top{width:100%;display:flex;align-content:flex-start}.tb-grid-column.tb-grid-align-center{width:100%;display:flex;align-content:center}.tb-grid-column.tb-grid-align-bottom{width:100%;display:flex;align-content:flex-end} .wp-block-toolset-blocks-grid.tb-grid[data-toolset-blocks-grid="ac5a9b338e066a035374a7c135358093"] { grid-template-columns: minmax(0, 1fr);grid-auto-flow: row } .wp-block-toolset-blocks-grid.tb-grid[data-toolset-blocks-grid="ac5a9b338e066a035374a7c135358093"]  > .tb-grid-column:nth-of-type(1n+1) { grid-column: 1 } .wp-block-toolset-blocks-grid-column.tb-grid-column[data-toolset-blocks-grid-column="3034fbe886c11054e95b46b09d3e4112"] { display: flex; } .tb-image{position:relative;transition:transform 0.25s ease}.wp-block-image .tb-image.aligncenter{margin-left:auto;margin-right:auto}.tb-image img{max-width:100%;height:auto;width:auto;transition:transform 0.25s ease}.tb-image .tb-image-caption-fit-to-image{display:table}.tb-image .tb-image-caption-fit-to-image .tb-image-caption{display:table-caption;caption-side:bottom} } 
On This Page:
Installing WPML Components
Case Study – Sydney Theme
Translating the Header
Translating Menus
Translating Sydney Theme’s Services and Other Custom Post Types
Translating Theme or Plugin Custom Elements
Translating the Post Body
Translating WordPress Widgets
Translating the Footer
Hiding the Language Switcher from the Settings Page
Creating a Language Configuration File for Your Theme
GetText Support for Hard-Coded Strings
WooCommerce Compatibility
Making Custom Elementor Widgets and Other Page Builder Widgets Translation-Ready
Tips and Debugging
1. Installing WPML Components
WPML includes several components. Some are required for your theme compatibility work and some are intended for site admins, who will later manage the site’s content.
You should activate the essential WPML components, which will allow you to fully translate your theme:
WPML core plugin
WPML String Translation add-on
To get them, go to your WPML account and click on Downloads .
Of course, you are welcome to learn about the other components in WPML core and addons .
2. Case Study – Sydney Theme
Let’s look at this example of a website created with the Sydney theme, from aThemes:
Example of a website built using the Sydney theme
As we go through the different elements in this site, we’ll learn how to translate rich themes or plugins with WPML.
The theme’s or plugin’s header comes from the WordPress general settings as displayed in the following image:
WordPress General Settings page
Since it’s not part of any post, we need to use WPML’s String Translation to translate it. Go to the WPML → String Translation page, search for the string by its content (i.e. “Site’s title”) and translate it.
Translating other texts coming from the theme and plugins using WPML’s String Translation page
You don’t need to do anything in the theme or plugin to make this happen. WPML handles it automatically. We showed how to translate the site name because we are going to use WPML’s String Translation for many other elements in your theme or plugin.
WPML translates WordPress menus without you needing to do anything. As long as your theme uses the standard WordPress menu system, WPML will translate the menus.
Automatic translation of menus that use the standard WordPress menu system
When you go to the Appearance → Menus page, you will see WPML’s menu translation controls. Learn more about translating menus to see how this works.
5. Translating Sydney Theme’s Services and Other Custom Post Types
The example theme that we are looking at uses a custom post type, “Services”. It is easy to translate it using WPML, with little configuration. It also applies to the “Testimonials”, “Clients”, and “Projects” post types.
We need to tell WPML that the “Services” custom post type is multilingual. This means that WPML offers users to translate it.
WPML allows three modes for translatable content:
Translatable, only show translated items
Translatable, use translation if available or fallback to default language
Not translatable
This gives you great flexibility in deciding what content gets translated and how the translations are displayed (or not).
We want to translate the “Services”, so we can show our offer in different languages.
Navigate to WPML → Settings and scroll down to the Post Types Translation . Select one of two Translatable options in the row(s) for the custom post types you want to be translatable and then Save .
Choosing which custom post types you want to be translatable
6. Translating Theme or Plugin Custom Elements
Many themes and plugins have unique features which store texts in the wp_options table. The slide captions feature, by Sydney, does that exactly.
Translating texts featured in the wp_options table
The theme or plugin saves these texts in the wp_options table and we need to tell WPML to translate them. We add this information to the Language Configuration File . There, we tell WPML which entries in the wp_options table require translation.
This technique is good when the keys for the options are fixed (like in most themes). If your theme uses an array of entries – which may grow with user input – you need to register these entries dynamically. Use WPML’s API functions to do this.
6.1 Adding Your Plugin’s Translations
To add translations to your plugin, we recommend creating a languages folder inside your plugin’s main folder and placing all your .mo files there.
Then, WordPress needs to load and associate them correctly with your plugin’s Text Domain. In order to do so, you need to call them with a load_plugin_textdomain function right after the header of your theme/plugin file. This code should be placed in a file located within the root folder of your plugin:
7. Translating the Post Body
WPML lets users translate content with ease. The post-edit screens include WPML’s translation controls, allowing to create new translations and edit existing ones.
Translating a post from the post editor
You don’t need to do anything in the theme or plugin to make this happen. Translating content is a core feature of WPML.
What you do need to check is that any text that your theme adds to the output is translatable. For example, the highlighted texts in this screenshot should be wrapped in gettext calls.
Ensuring text that your theme adds to the output is translatable
If you’re new to using gettext , learn more about it in our theme texts translation FAQ .
WPML lets users translate the content of text widgets. It also translates titles of all other widgets. If your theme or plugin creates its own custom WordPress widgets, make sure that you pass their titles through the standard WordPress filters. The code will look like this:
function widget( $args, $instance ) {
extract($args);
$title = apply_filters( 'widget_title', empty($instance['title']) ? '' : $instance['title'], $instance );
}
This way, WPML will allow users to translate the titles of your widgets via the String Translation screen. For additional information check out the page about translating widgets .
Just like many other themes, this one uses widgets to store the footer texts.
Translating widget text using WPML’s String Translation
WPML allows users to translate the titles and content of your widgets via the String Translation screen.
10. Hiding the Language Switcher from the Settings Page
By default, WPML adds a language switcher to the WordPress admin bar. It is visible to logged-in users on both the backend and front end of your WordPress website.
The language switcher in the top admin bar
Sometimes, you may want to hide the language switcher from the settings page of your theme or plugin. This can prevent users from using the language switcher in the wrong way, like by trying to set different options for each language.
You can do this by adding the code below to your functions.php file. Just make sure to adapt it to your own needs.
Hide the language switcher from the settings page
//Make sure to rename the function before adding to your plugin
add_filter( 'wpml_show_admin_language_switcher', 'compsupp_disable_wpml_admin_lang_switcher' );
function compsupp_disable_wpml_admin_lang_switcher( $state ) {
global $pagenow;
// Add the admin pages that we need to hide the language switcher
$admin_pages_to_hide_ls = array(
'admin-page-slug', 'another-admin-page-slug', 'one-more-admin-page-slug'
);
// We can also have a filter here in case we need to add/remove pages later
$admin_pages_to_hide_ls = apply_filters( 'compsupp_filter_disable_wpml_lang_switcher_in_admin', $admin_pages_to_hide_ls);
if (
$pagenow == 'admin.php'
&& isset( $_GET['page'] )
&& in_array( $_GET['page'], $admin_pages_to_hide_ls)
) {
$state = false;
}
return $state;
}
11. Creating a Language Configuration File for Your Theme
When you are done and your theme is fully WPML-compatible, you probably want to make it to be as easy as possible for others to run multilingual sites with the theme.
Create a language configuration file for your theme and save it in the theme’s root directory. The file tells WPML which custom post types, taxonomy, fields and options are translatable.
This tiny XML file will save hours for your clients, allowing them to run multilingual sites without effort. Your clients will get everything working, without the need to configure what to translate. This will also help you save on support work.
12. GetText Support for Hard-Coded Strings
Although this is not strictly related to WPML, you should remember to wrap all the strings in your theme in GetText calls. This means that hard-coded texts will appear in the correct language on the site. You should do it for both, the theme (or plugin) texts that appear in the WordPress admin area, as well as the texts displayed on the front-end.
All WordPress themes and plugins, whether they are multilingual-ready or not, should use GetText to translate hard-coded strings. The WordPress default themes use GetText very accurately and are a great reference if you are just getting started with it.
Wrapping texts in GetText calls is a big subject by itself. If you are not familiar with it or need help debugging localization for your code, have a look at these:
WPML integrates fully with GetText. Once you have wrapped hard-coded strings in GetText calls, you will be able to translate them directly from the WordPress admin using WPML’s String Translation screen. WPML can also export and import .po files for you, letting you translate your theme’s strings all from within WordPress.
13. WooCommerce Compatibility
Themes that include a WooCommerce section may need to follow a few other suggestions. Mainly, you should use get_options to get the IDs of WooCommerce pages. Have a look at our guide on making WooCommerce themes multilingual and multi-currency-ready .
14. Making Custom Elementor Widgets and Other Page Builder Widgets Translation-Ready
To allow users of your theme or plugin to translate your custom widgets, you first need to make them translatable.
To learn how, read our comprehensive guide on registering custom widgets for Elementor and other page builders for translation .
To make it easier for you to follow, the guide provides both written and video tutorials, using both basic and advanced widgets from Elementor as examples.
14. Tips and Debugging
If you are already familiar with WPML basics and are working on compatibility with your theme or plugin, have a look at the debugging theme compatibility guide . You will find tips and ideas on how to make your theme compatible with WPML.
If you need our help, just get in touch. Visit our technical support forum , explain what’s wrong and we’ll help you.