
@charset "UTF-8";


/*      Request ID: df42eaf6a78b6786f4cccd08869c8122_1760929634 (01/14/2026 3:31pm) (minifier disabled) (vY3BDQMhDARbSQEB5xOlnNNxrMAS+BA2oHSfk/JKA3mNdh47lM8K0nNYXlBDl5/hIqYvPLHyXuAFRm2EwseWrRbaWFJHZIgpWUaFUuDk2p7gnqT2Lpd5OF3c0F0YEq+XyuIP1fuN/hD/ws+X16v5AQ==)      */

/**
 * Swiper 11.1.15
 * Most modern mobile touch slider and framework with hardware accelerated transitions
 * https://swiperjs.com
 *
 * Copyright 2014-2024 Vladimir Kharlampidi
 *
 * Released under the MIT License
 *
 * Released on: November 18, 2024
 */

@font-face{font-family:swiper-icons;src:url('data:application/font-woff;charset=utf-8;base64, d09GRgABAAAAAAZgABAAAAAADAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABGRlRNAAAGRAAAABoAAAAci6qHkUdERUYAAAWgAAAAIwAAACQAYABXR1BPUwAABhQAAAAuAAAANuAY7+xHU1VCAAAFxAAAAFAAAABm2fPczU9TLzIAAAHcAAAASgAAAGBP9V5RY21hcAAAAkQAAACIAAABYt6F0cBjdnQgAAACzAAAAAQAAAAEABEBRGdhc3AAAAWYAAAACAAAAAj//wADZ2x5ZgAAAywAAADMAAAD2MHtryVoZWFkAAABbAAAADAAAAA2E2+eoWhoZWEAAAGcAAAAHwAAACQC9gDzaG10eAAAAigAAAAZAAAArgJkABFsb2NhAAAC0AAAAFoAAABaFQAUGG1heHAAAAG8AAAAHwAAACAAcABAbmFtZQAAA/gAAAE5AAACXvFdBwlwb3N0AAAFNAAAAGIAAACE5s74hXjaY2BkYGAAYpf5Hu/j+W2+MnAzMYDAzaX6QjD6/4//Bxj5GA8AuRwMYGkAPywL13jaY2BkYGA88P8Agx4j+/8fQDYfA1AEBWgDAIB2BOoAeNpjYGRgYNBh4GdgYgABEMnIABJzYNADCQAACWgAsQB42mNgYfzCOIGBlYGB0YcxjYGBwR1Kf2WQZGhhYGBiYGVmgAFGBiQQkOaawtDAoMBQxXjg/wEGPcYDDA4wNUA2CCgwsAAAO4EL6gAAeNpj2M0gyAACqxgGNWBkZ2D4/wMA+xkDdgAAAHjaY2BgYGaAYBkGRgYQiAHyGMF8FgYHIM3DwMHABGQrMOgyWDLEM1T9/w8UBfEMgLzE////P/5//f/V/xv+r4eaAAeMbAxwIUYmIMHEgKYAYjUcsDAwsLKxc3BycfPw8jEQA/gZBASFhEVExcQlJKWkZWTl5BUUlZRVVNXUNTQZBgMAAMR+E+gAEQFEAAAAKgAqACoANAA+AEgAUgBcAGYAcAB6AIQAjgCYAKIArAC2AMAAygDUAN4A6ADyAPwBBgEQARoBJAEuATgBQgFMAVYBYAFqAXQBfgGIAZIBnAGmAbIBzgHsAAB42u2NMQ6CUAyGW568x9AneYYgm4MJbhKFaExIOAVX8ApewSt4Bic4AfeAid3VOBixDxfPYEza5O+Xfi04YADggiUIULCuEJK8VhO4bSvpdnktHI5QCYtdi2sl8ZnXaHlqUrNKzdKcT8cjlq+rwZSvIVczNiezsfnP/uznmfPFBNODM2K7MTQ45YEAZqGP81AmGGcF3iPqOop0r1SPTaTbVkfUe4HXj97wYE+yNwWYxwWu4v1ugWHgo3S1XdZEVqWM7ET0cfnLGxWfkgR42o2PvWrDMBSFj/IHLaF0zKjRgdiVMwScNRAoWUoH78Y2icB/yIY09An6AH2Bdu/UB+yxopYshQiEvnvu0dURgDt8QeC8PDw7Fpji3fEA4z/PEJ6YOB5hKh4dj3EvXhxPqH/SKUY3rJ7srZ4FZnh1PMAtPhwP6fl2PMJMPDgeQ4rY8YT6Gzao0eAEA409DuggmTnFnOcSCiEiLMgxCiTI6Cq5DZUd3Qmp10vO0LaLTd2cjN4fOumlc7lUYbSQcZFkutRG7g6JKZKy0RmdLY680CDnEJ+UMkpFFe1RN7nxdVpXrC4aTtnaurOnYercZg2YVmLN/d/gczfEimrE/fs/bOuq29Zmn8tloORaXgZgGa78yO9/cnXm2BpaGvq25Dv9S4E9+5SIc9PqupJKhYFSSl47+Qcr1mYNAAAAeNptw0cKwkAAAMDZJA8Q7OUJvkLsPfZ6zFVERPy8qHh2YER+3i/BP83vIBLLySsoKimrqKqpa2hp6+jq6RsYGhmbmJqZSy0sraxtbO3sHRydnEMU4uR6yx7JJXveP7WrDycAAAAAAAH//wACeNpjYGRgYOABYhkgZgJCZgZNBkYGLQZtIJsFLMYAAAw3ALgAeNolizEKgDAQBCchRbC2sFER0YD6qVQiBCv/H9ezGI6Z5XBAw8CBK/m5iQQVauVbXLnOrMZv2oLdKFa8Pjuru2hJzGabmOSLzNMzvutpB3N42mNgZGBg4GKQYzBhYMxJLMlj4GBgAYow/P/PAJJhLM6sSoWKfWCAAwDAjgbRAAB42mNgYGBkAIIbCZo5IPrmUn0hGA0AO8EFTQAA');font-weight:400;font-style:normal}:root{--swiper-theme-color:#007aff}:host{position:relative;display:block;margin-left:auto;margin-right:auto;z-index:1}.swiper{margin-left:auto;margin-right:auto;position:relative;overflow:hidden;list-style:none;padding:0;z-index:1;display:block}.swiper-vertical>.swiper-wrapper{flex-direction:column}.swiper-wrapper{position:relative;width:100%;height:100%;z-index:1;display:flex;transition-property:transform;transition-timing-function:var(--swiper-wrapper-transition-timing-function,initial);box-sizing:content-box}.swiper-android .swiper-slide,.swiper-ios .swiper-slide,.swiper-wrapper{transform:translate3d(0px,0,0)}.swiper-horizontal{touch-action:pan-y}.swiper-vertical{touch-action:pan-x}.swiper-slide{flex-shrink:0;width:100%;height:100%;position:relative;transition-property:transform;display:block}.swiper-slide-invisible-blank{visibility:hidden}.swiper-autoheight,.swiper-autoheight .swiper-slide{height:auto}.swiper-autoheight .swiper-wrapper{align-items:flex-start;transition-property:transform,height}.swiper-backface-hidden .swiper-slide{transform:translateZ(0);-webkit-backface-visibility:hidden;backface-visibility:hidden}.swiper-3d.swiper-css-mode .swiper-wrapper{perspective:1200px}.swiper-3d .swiper-wrapper{transform-style:preserve-3d}.swiper-3d{perspective:1200px}.swiper-3d .swiper-cube-shadow,.swiper-3d .swiper-slide{transform-style:preserve-3d}.swiper-css-mode>.swiper-wrapper{overflow:auto;scrollbar-width:none;-ms-overflow-style:none}.swiper-css-mode>.swiper-wrapper::-webkit-scrollbar{display:none}.swiper-css-mode>.swiper-wrapper>.swiper-slide{scroll-snap-align:start start}.swiper-css-mode.swiper-horizontal>.swiper-wrapper{scroll-snap-type:x mandatory}.swiper-css-mode.swiper-vertical>.swiper-wrapper{scroll-snap-type:y mandatory}.swiper-css-mode.swiper-free-mode>.swiper-wrapper{scroll-snap-type:none}.swiper-css-mode.swiper-free-mode>.swiper-wrapper>.swiper-slide{scroll-snap-align:none}.swiper-css-mode.swiper-centered>.swiper-wrapper::before{content:'';flex-shrink:0;order:9999}.swiper-css-mode.swiper-centered>.swiper-wrapper>.swiper-slide{scroll-snap-align:center center;scroll-snap-stop:always}.swiper-css-mode.swiper-centered.swiper-horizontal>.swiper-wrapper>.swiper-slide:first-child{margin-inline-start:var(--swiper-centered-offset-before)}.swiper-css-mode.swiper-centered.swiper-horizontal>.swiper-wrapper::before{height:100%;min-height:1px;width:var(--swiper-centered-offset-after)}.swiper-css-mode.swiper-centered.swiper-vertical>.swiper-wrapper>.swiper-slide:first-child{margin-block-start:var(--swiper-centered-offset-before)}.swiper-css-mode.swiper-centered.swiper-vertical>.swiper-wrapper::before{width:100%;min-width:1px;height:var(--swiper-centered-offset-after)}.swiper-3d .swiper-slide-shadow,.swiper-3d .swiper-slide-shadow-bottom,.swiper-3d .swiper-slide-shadow-left,.swiper-3d .swiper-slide-shadow-right,.swiper-3d .swiper-slide-shadow-top{position:absolute;left:0;top:0;width:100%;height:100%;pointer-events:none;z-index:10}.swiper-3d .swiper-slide-shadow{background:rgba(0,0,0,.15)}.swiper-3d .swiper-slide-shadow-left{background-image:linear-gradient(to left,rgba(0,0,0,.5),rgba(0,0,0,0))}.swiper-3d .swiper-slide-shadow-right{background-image:linear-gradient(to right,rgba(0,0,0,.5),rgba(0,0,0,0))}.swiper-3d .swiper-slide-shadow-top{background-image:linear-gradient(to top,rgba(0,0,0,.5),rgba(0,0,0,0))}.swiper-3d .swiper-slide-shadow-bottom{background-image:linear-gradient(to bottom,rgba(0,0,0,.5),rgba(0,0,0,0))}.swiper-lazy-preloader{width:42px;height:42px;position:absolute;left:50%;top:50%;margin-left:-21px;margin-top:-21px;z-index:10;transform-origin:50%;box-sizing:border-box;border:4px solid var(--swiper-preloader-color,var(--swiper-theme-color));border-radius:50%;border-top-color:transparent}.swiper-watch-progress .swiper-slide-visible .swiper-lazy-preloader,.swiper:not(.swiper-watch-progress) .swiper-lazy-preloader{animation:swiper-preloader-spin 1s infinite linear}.swiper-lazy-preloader-white{--swiper-preloader-color:#fff}.swiper-lazy-preloader-black{--swiper-preloader-color:#000}@keyframes swiper-preloader-spin{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}.swiper-virtual .swiper-slide{-webkit-backface-visibility:hidden;transform:translateZ(0)}.swiper-virtual.swiper-css-mode .swiper-wrapper::after{content:'';position:absolute;left:0;top:0;pointer-events:none}.swiper-virtual.swiper-css-mode.swiper-horizontal .swiper-wrapper::after{height:1px;width:var(--swiper-virtual-size)}.swiper-virtual.swiper-css-mode.swiper-vertical .swiper-wrapper::after{width:1px;height:var(--swiper-virtual-size)}:root{--swiper-navigation-size:44px}.swiper-button-next,.swiper-button-prev{position:absolute;top:var(--swiper-navigation-top-offset,50%);width:calc(var(--swiper-navigation-size)/ 44 * 27);height:var(--swiper-navigation-size);margin-top:calc(0px - (var(--swiper-navigation-size)/ 2));z-index:10;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--swiper-navigation-color,var(--swiper-theme-color))}.swiper-button-next.swiper-button-disabled,.swiper-button-prev.swiper-button-disabled{opacity:.35;cursor:auto;pointer-events:none}.swiper-button-next.swiper-button-hidden,.swiper-button-prev.swiper-button-hidden{opacity:0;cursor:auto;pointer-events:none}.swiper-navigation-disabled .swiper-button-next,.swiper-navigation-disabled .swiper-button-prev{display:none!important}.swiper-button-next svg,.swiper-button-prev svg{width:100%;height:100%;object-fit:contain;transform-origin:center}.swiper-rtl .swiper-button-next svg,.swiper-rtl .swiper-button-prev svg{transform:rotate(180deg)}.swiper-button-prev,.swiper-rtl .swiper-button-next{left:var(--swiper-navigation-sides-offset,10px);right:auto}.swiper-button-next,.swiper-rtl .swiper-button-prev{right:var(--swiper-navigation-sides-offset,10px);left:auto}.swiper-button-lock{display:none}.swiper-button-next:after,.swiper-button-prev:after{font-family:swiper-icons;font-size:var(--swiper-navigation-size);text-transform:none!important;letter-spacing:0;font-variant:initial;line-height:1}.swiper-button-prev:after,.swiper-rtl .swiper-button-next:after{content:'prev'}.swiper-button-next,.swiper-rtl .swiper-button-prev{right:var(--swiper-navigation-sides-offset,10px);left:auto}.swiper-button-next:after,.swiper-rtl .swiper-button-prev:after{content:'next'}.swiper-pagination{position:absolute;text-align:center;transition:.3s opacity;transform:translate3d(0,0,0);z-index:10}.swiper-pagination.swiper-pagination-hidden{opacity:0}.swiper-pagination-disabled>.swiper-pagination,.swiper-pagination.swiper-pagination-disabled{display:none!important}.swiper-horizontal>.swiper-pagination-bullets,.swiper-pagination-bullets.swiper-pagination-horizontal,.swiper-pagination-custom,.swiper-pagination-fraction{bottom:var(--swiper-pagination-bottom,8px);top:var(--swiper-pagination-top,auto);left:0;width:100%}.swiper-pagination-bullets-dynamic{overflow:hidden;font-size:0}.swiper-pagination-bullets-dynamic .swiper-pagination-bullet{transform:scale(.33);position:relative}.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active{transform:scale(1)}.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-main{transform:scale(1)}.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev{transform:scale(.66)}.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev-prev{transform:scale(.33)}.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next{transform:scale(.66)}.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next-next{transform:scale(.33)}.swiper-pagination-bullet{width:var(--swiper-pagination-bullet-width,var(--swiper-pagination-bullet-size,8px));height:var(--swiper-pagination-bullet-height,var(--swiper-pagination-bullet-size,8px));display:inline-block;border-radius:var(--swiper-pagination-bullet-border-radius,50%);background:var(--swiper-pagination-bullet-inactive-color,#000);opacity:var(--swiper-pagination-bullet-inactive-opacity, .2)}button.swiper-pagination-bullet{border:none;margin:0;padding:0;box-shadow:none;-webkit-appearance:none;appearance:none}.swiper-pagination-clickable .swiper-pagination-bullet{cursor:pointer}.swiper-pagination-bullet:only-child{display:none!important}.swiper-pagination-bullet-active{opacity:var(--swiper-pagination-bullet-opacity, 1);background:var(--swiper-pagination-color,var(--swiper-theme-color))}.swiper-pagination-vertical.swiper-pagination-bullets,.swiper-vertical>.swiper-pagination-bullets{right:var(--swiper-pagination-right,8px);left:var(--swiper-pagination-left,auto);top:50%;transform:translate3d(0px,-50%,0)}.swiper-pagination-vertical.swiper-pagination-bullets .swiper-pagination-bullet,.swiper-vertical>.swiper-pagination-bullets .swiper-pagination-bullet{margin:var(--swiper-pagination-bullet-vertical-gap,6px) 0;display:block}.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic,.swiper-vertical>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic{top:50%;transform:translateY(-50%);width:8px}.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,.swiper-vertical>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet{display:inline-block;transition:.2s transform,.2s top}.swiper-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet,.swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet{margin:0 var(--swiper-pagination-bullet-horizontal-gap,4px)}.swiper-horizontal>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic,.swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic{left:50%;transform:translateX(-50%);white-space:nowrap}.swiper-horizontal>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,.swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet{transition:.2s transform,.2s left}.swiper-horizontal.swiper-rtl>.swiper-pagination-bullets-dynamic .swiper-pagination-bullet{transition:.2s transform,.2s right}.swiper-pagination-fraction{color:var(--swiper-pagination-fraction-color,inherit)}.swiper-pagination-progressbar{background:var(--swiper-pagination-progressbar-bg-color,rgba(0,0,0,.25));position:absolute}.swiper-pagination-progressbar .swiper-pagination-progressbar-fill{background:var(--swiper-pagination-color,var(--swiper-theme-color));position:absolute;left:0;top:0;width:100%;height:100%;transform:scale(0);transform-origin:left top}.swiper-rtl .swiper-pagination-progressbar .swiper-pagination-progressbar-fill{transform-origin:right top}.swiper-horizontal>.swiper-pagination-progressbar,.swiper-pagination-progressbar.swiper-pagination-horizontal,.swiper-pagination-progressbar.swiper-pagination-vertical.swiper-pagination-progressbar-opposite,.swiper-vertical>.swiper-pagination-progressbar.swiper-pagination-progressbar-opposite{width:100%;height:var(--swiper-pagination-progressbar-size,4px);left:0;top:0}.swiper-horizontal>.swiper-pagination-progressbar.swiper-pagination-progressbar-opposite,.swiper-pagination-progressbar.swiper-pagination-horizontal.swiper-pagination-progressbar-opposite,.swiper-pagination-progressbar.swiper-pagination-vertical,.swiper-vertical>.swiper-pagination-progressbar{width:var(--swiper-pagination-progressbar-size,4px);height:100%;left:0;top:0}.swiper-pagination-lock{display:none}.swiper-scrollbar{border-radius:var(--swiper-scrollbar-border-radius,10px);position:relative;touch-action:none;background:var(--swiper-scrollbar-bg-color,rgba(0,0,0,.1))}.swiper-scrollbar-disabled>.swiper-scrollbar,.swiper-scrollbar.swiper-scrollbar-disabled{display:none!important}.swiper-horizontal>.swiper-scrollbar,.swiper-scrollbar.swiper-scrollbar-horizontal{position:absolute;left:var(--swiper-scrollbar-sides-offset,1%);bottom:var(--swiper-scrollbar-bottom,4px);top:var(--swiper-scrollbar-top,auto);z-index:50;height:var(--swiper-scrollbar-size,4px);width:calc(100% - 2 * var(--swiper-scrollbar-sides-offset,1%))}.swiper-scrollbar.swiper-scrollbar-vertical,.swiper-vertical>.swiper-scrollbar{position:absolute;left:var(--swiper-scrollbar-left,auto);right:var(--swiper-scrollbar-right,4px);top:var(--swiper-scrollbar-sides-offset,1%);z-index:50;width:var(--swiper-scrollbar-size,4px);height:calc(100% - 2 * var(--swiper-scrollbar-sides-offset,1%))}.swiper-scrollbar-drag{height:100%;width:100%;position:relative;background:var(--swiper-scrollbar-drag-bg-color,rgba(0,0,0,.5));border-radius:var(--swiper-scrollbar-border-radius,10px);left:0;top:0}.swiper-scrollbar-cursor-drag{cursor:move}.swiper-scrollbar-lock{display:none}.swiper-zoom-container{width:100%;height:100%;display:flex;justify-content:center;align-items:center;text-align:center}.swiper-zoom-container>canvas,.swiper-zoom-container>img,.swiper-zoom-container>svg{max-width:100%;max-height:100%;object-fit:contain}.swiper-slide-zoomed{cursor:move;touch-action:none}.swiper .swiper-notification{position:absolute;left:0;top:0;pointer-events:none;opacity:0;z-index:-1000}.swiper-free-mode>.swiper-wrapper{transition-timing-function:ease-out;margin:0 auto}.swiper-grid>.swiper-wrapper{flex-wrap:wrap}.swiper-grid-column>.swiper-wrapper{flex-wrap:wrap;flex-direction:column}.swiper-fade.swiper-free-mode .swiper-slide{transition-timing-function:ease-out}.swiper-fade .swiper-slide{pointer-events:none;transition-property:opacity}.swiper-fade .swiper-slide .swiper-slide{pointer-events:none}.swiper-fade .swiper-slide-active{pointer-events:auto}.swiper-fade .swiper-slide-active .swiper-slide-active{pointer-events:auto}.swiper.swiper-cube{overflow:visible}.swiper-cube .swiper-slide{pointer-events:none;-webkit-backface-visibility:hidden;backface-visibility:hidden;z-index:1;visibility:hidden;transform-origin:0 0;width:100%;height:100%}.swiper-cube .swiper-slide .swiper-slide{pointer-events:none}.swiper-cube.swiper-rtl .swiper-slide{transform-origin:100% 0}.swiper-cube .swiper-slide-active,.swiper-cube .swiper-slide-active .swiper-slide-active{pointer-events:auto}.swiper-cube .swiper-slide-active,.swiper-cube .swiper-slide-next,.swiper-cube .swiper-slide-prev{pointer-events:auto;visibility:visible}.swiper-cube .swiper-cube-shadow{position:absolute;left:0;bottom:0px;width:100%;height:100%;opacity:.6;z-index:0}.swiper-cube .swiper-cube-shadow:before{content:'';background:#000;position:absolute;left:0;top:0;bottom:0;right:0;filter:blur(50px)}.swiper-cube .swiper-slide-next+.swiper-slide{pointer-events:auto;visibility:visible}.swiper-cube .swiper-slide-shadow-cube.swiper-slide-shadow-bottom,.swiper-cube .swiper-slide-shadow-cube.swiper-slide-shadow-left,.swiper-cube .swiper-slide-shadow-cube.swiper-slide-shadow-right,.swiper-cube .swiper-slide-shadow-cube.swiper-slide-shadow-top{z-index:0;-webkit-backface-visibility:hidden;backface-visibility:hidden}.swiper.swiper-flip{overflow:visible}.swiper-flip .swiper-slide{pointer-events:none;-webkit-backface-visibility:hidden;backface-visibility:hidden;z-index:1}.swiper-flip .swiper-slide .swiper-slide{pointer-events:none}.swiper-flip .swiper-slide-active,.swiper-flip .swiper-slide-active .swiper-slide-active{pointer-events:auto}.swiper-flip .swiper-slide-shadow-flip.swiper-slide-shadow-bottom,.swiper-flip .swiper-slide-shadow-flip.swiper-slide-shadow-left,.swiper-flip .swiper-slide-shadow-flip.swiper-slide-shadow-right,.swiper-flip .swiper-slide-shadow-flip.swiper-slide-shadow-top{z-index:0;-webkit-backface-visibility:hidden;backface-visibility:hidden}.swiper-creative .swiper-slide{-webkit-backface-visibility:hidden;backface-visibility:hidden;overflow:hidden;transition-property:transform,opacity,height}.swiper.swiper-cards{overflow:visible}.swiper-cards .swiper-slide{transform-origin:center bottom;-webkit-backface-visibility:hidden;backface-visibility:hidden;overflow:hidden}
html {
  font-size: 16px; }
  @media screen and (max-width: 599px) {
    html {
      font-size: 14.3px; } }

#preload {
  display: none; }

body {
  width: 100%; }

.livewhale header.header {
  margin-top: 40px; }

.wrapper {
  overflow: auto;
  scrollbar-width: thin;
  scrollbar-color: transparent transparent; }
  .wrapper:-webkit-scrollbar {
    width: 0;
    /* Chrome, Safari, Edge */
    height: 0; }

.subheader {
  text-align: inherit; }

.subheader__title {
  margin-top: 7px; }

.headline-h1 {
  font-size: 4rem;
  line-height: 1.25;
  margin-top: .75rem; }
  @media screen and (max-width: 1439px) {
    .headline-h1 {
      font-size: 3.5rem; } }
  @media screen and (max-width: 1179px) {
    .headline-h1 {
      font-size: 3rem; } }

.headline-h2 {
  font-family: 'HK Grotesk', Arial, sans-serif;
  font-size: 2.5rem !important;
  font-weight: 600;
  margin-bottom: 30px;
  line-height: 1.25; }

.container > div > .headline-h3:first-child,
.content__inner > .headline-h3:first-child {
  margin-top: 0; }

.sub-section .headline-h3 {
  border-bottom: 0; }

.headline-h4 {
  font-size: 1.375rem;
  font-weight: bold;
  line-height: 1.5;
  margin-bottom: 1rem;
  margin-top: 2rem; }

.page__content {
  padding: 0;
  font-family: 'HK Grotesk', Arial, sans-serif;
  line-height: 1.65;
  color: #000;
  font-size: 1.125rem; }
  .page__content p {
    color: inherit !important;
    margin-bottom: 1.85rem; }
    .page__content p.note {
      font-size: 1rem; }
    .page__content p:last-child {
      margin-bottom: 0; }

.background-light {
  background-color: #f7f7f7; }

.icon-rectangle {
  width: 5rem;
  height: .375rem; }

.link-icon-rectangle {
  font-size: .875rem; }

.link-for-story {
  margin-left: .29rem; }

.link-icon-rectangle:before {
  top: .5rem;
  width: .875rem;
  height: .29rem;
  margin-right: 0; }

.container {
  margin-bottom: 4rem; }
  .container:last-child {
    margin-bottom: 0; }

.typographic-content a {
  transition: color .5s ease, border-bottom .5s ease; }
  .typographic-content a:not(.link-icon-rectangle) {
    border-bottom: 2px solid #ffcd00; }
  .typographic-content a:hover {
    border-bottom: 2px solid #828282;
    color: #828282; }

.typographic-content .table .column {
  display: flex;
  flex-direction: column;
  border: 0.1875rem solid black;
  margin-right: -.1875rem;
  margin-top: -.1875rem; }
  .typographic-content .table .column .headline-h3 {
    border-bottom: 0;
    margin-top: 0;
    text-align: center; }
  .typographic-content .table .column .table-header {
    min-height: calc(6.2rem + .625rem);
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: #ebebeb;
    padding: .625rem 1.875rem;
    border-bottom: .1875rem solid #000; }
    .typographic-content .table .column .table-header .headline-h3 {
      margin-bottom: 0; }
  .typographic-content .table .column .table-content {
    display: flex;
    flex-grow: 1;
    background-color: #fff;
    padding: .625rem 1.875rem; }
    .typographic-content .table .column .table-content ul {
      margin-bottom: 1.25rem;
      margin-left: 0; }
    .typographic-content .table .column .table-content li {
      margin-top: 1.25rem; }

.typographic-content ul {
  list-style-position: inside !important;
  list-style-type: disc;
  margin-left: 2.1875rem; }
  .typographic-content ul li {
    padding-left: 1.3em;
    /* Adjust padding for bullet size */
    text-indent: -1.3em;
    /* Indent text to align with bullet */ }

.typographic-content .non-typographic ul {
  list-style-position: outside !important;
  list-style-type: none;
  margin-left: 0; }
  .typographic-content .non-typographic ul li {
    padding-left: 0;
    text-indent: 0; }

.button {
  padding: .94rem 2.34rem 1rem;
  margin-top: 1rem; }

.button__text {
  font-size: .93rem; }

.image-container {
  background-color: transparent; }
  .image-container .lw_image img {
    max-height: none; }

#map img {
  border: 2px solid #4d4d4d; }

.subsection {
  margin-top: 32px; }

.lw_widget_navigation .lw_subnav {
  margin-left: 0;
  padding-left: 25px;
  margin-bottom: 2em; }

.page__sidebar .lw_widget_navigation ul li :before {
  content: none; }

.page__sidebar .lw_widget_navigation ul li a:before {
  content: "";
  position: absolute;
  top: 4px;
  left: 0;
  width: 0;
  height: calc(100% - 7px);
  visibility: hidden;
  opacity: 0;
  background-color: #ffcd00;
  -webkit-transition: opacity .4s ease .1s, visibility .4s ease .1s, width .4s ease .1s;
  transition: opacity .4s ease .1s, visibility .4s ease .1s, width .4s ease .1s; }

.page__sidebar .lw_widget_navigation ul li.lw_current :before {
  visibility: initial;
  width: initial;
  opacity: initial; }

.page__sidebar .lw_widget_navigation ul li.lw_current > a:before {
  visibility: visible;
  width: 6px;
  opacity: 1; }

.page__sidebar .lw_widget_navigation > ul > li > a:hover {
  padding-left: 25px;
  font-weight: 700;
  color: #000; }

.page__sidebar .lw_widget_navigation ul li.lw_current ul.lw_subnav :hover {
  padding-left: 0; }

.sidebar__list .lw_widget_navigation ul.lw_subnav li {
  margin-top: 1em; }

.page__sidebar .lw_widget_navigation ul.lw_subnav li a {
  font-family: HK Grotesk, Arial, sans-serif;
  font-weight: 400;
  color: #000;
  padding-left: 0;
  display: inline-block;
  font-size: 16px;
  border-bottom: 2px solid transparent !important;
  transition: border-bottom-color .1s ease !important; }

.sidebar__list .lw_widget_navigation ul.lw_subnav li:not(.lw_current_section) a:hover {
  color: #828282; }

.sidebar__list .lw_widget_navigation ul.lw_subnav li.lw_current_section a {
  font-weight: bold !important;
  border-bottom: 2px solid #ffcd00 !important; }

.navigation {
  will-change: width, visibility; }

.animated-primarymenu .side__content {
  overflow: auto;
  scrollbar-width: thin;
  scrollbar-color: transparent transparent; }
  .animated-primarymenu .side__content:-webkit-scrollbar {
    width: 0;
    /* Chrome, Safari, Edge */
    height: 0; }

header {
  background-color: transparent !important; }
  header:before {
    width: 100%;
    height: 80px;
    position: absolute;
    right: 0;
    top: 0;
    bottom: auto;
    content: "";
    display: block;
    pointer-events: none;
    background: linear-gradient(to bottom, black, rgba(0, 0, 0, 0.4));
    z-index: -1; }
  header .nav_header__background {
    background-color: white;
    position: absolute;
    top: 0;
    left: 0;
    width: 0;
    height: 80px;
    transition: width 650ms cubic-bezier(0.25, 0.1, 0.25, 1);
    z-index: -1; }
  header .header__background {
    background-color: transparent;
    opacity: 1;
    transition: background-color 0.3s ease-in-out, transform 0.3s ease-in-out; }
    @media screen and (max-width: 1179px) {
      header .header__background {
        transform: none;
        opacity: 1;
        background-color: black; } }
  header.scrolled .header__background {
    opacity: 1;
    transform: translateY(0); }

body.gradient-hidden header:before {
  background: none; }

body.gradient-hidden .header__background {
  transition: none;
  background-color: #fff; }

.sticky-header-hero header {
  background: none; }

.sticky-header-hero .header__background,
.sticky-header-hero header.scrolled .header__background {
  background-color: white !important;
  transition: background-color 0.3s ease-in-out; }

.header-hero-container .image-container {
  transition: padding 0.3s ease;
  min-height: 250px;
  width: 100%;
  display: flex; }
  .header-hero-container .image-container picture {
    max-height: none;
    width: 100%; }
    .header-hero-container .image-container picture img {
      width: 100%;
      height: 100%;
      object-fit: cover; }
  @media screen and (max-width: 1179px) {
    .header-hero-container .image-container {
      padding-top: 80px; } }

.menu-open header .nav_header__background {
  width: 100%; }

@media screen and (max-width: 1179px) {
  .menu-open header .header__background {
    background-color: transparent; } }

.menu-open .header__background,
.sticky-header .header__background,
[data-page=home].menu-open .header__background,
[data-page=home].personalization-open .header__background,
[data-page=home].sticky-header .header__background {
  opacity: 0;
  transform: translateY(0); }

.menu-open .header__background,
.sticky-header-hero .header__background,
[data-page=home].menu-open .header__background,
[data-page=home].personalization-open .header__background,
[data-page=home].sticky-header-hero .header__background {
  opacity: 1;
  transform: translateY(0); }

.header__nav-item-link,
.header__menu-label,
.sticky-header .header__nav-item-link,
.sticky-header .header__menu-label {
  color: #fff;
  fill: #fff; }

.sticky-header-hero .header__nav-item-link,
.sticky-header-hero .header__menu-label {
  color: #000; }

.header__nav-item-link--search,
.sticky-header .header__nav-item-link--search {
  background: 0 0.35em url(/live/resource/image/_ingredients/themes/global/assets/images/icon_magnifierWhite.svg) no-repeat; }

.sticky-header-hero .header__nav-item-link--search {
  background: 0 0.35em url(/live/resource/image/_ingredients/themes/global/assets/images/icon_magnifierBlack.svg) no-repeat; }

.header .hamburger {
  stroke: #fff; }

.menu-open .header .hamburger {
  stroke: #000; }

.sticky-header .header .hamburger {
  stroke: #fff; }

.sticky-header-hero .header .hamburger {
  stroke: #000; }

.header__logo,
.sticky-header .header__logo {
  background-image: url(/live/resource/image/_ingredients/themes/global/assets/images/logo_white_larger.svg);
  height: 46px; }

.sticky-header-hero .header__logo {
  background-image: url(/live/resource/image/_ingredients/themes/global/assets/images/logo_black_larger.svg);
  height: 46px; }

.sidebar {
  padding-left: 0;
  padding-right: 0; }

.wrapper {
  padding-top: 0; }

@media (max-width: 900px) {
  .header__logo,
  .sticky-header .header__logo {
    background-image: url(/live/resource/image/_ingredients/themes/global/assets/images/logomark_white_larger.svg); }
  .sticky-header-hero .header__logo {
    background-image: url(/live/resource/image/_ingredients/themes/global/assets/images/logomark_black_larger.svg); } }

.accordion-list {
  padding-top: 50px; }
  .accordion-list:first-child {
    padding-top: 0; }

.accordion-list__item {
  padding: 0 4rem 0 0;
  margin-bottom: 2.5rem;
  border: 1px solid #d6d6d6; }
  .accordion-list__item:last-of-type {
    border: 1px solid #d6d6d6; }
  .accordion-list__item.complete {
    border: 1px solid #87cb86; }
    .accordion-list__item.complete:last-of-type {
      border: 1px solid #87cb86; }

.accordion-list__item-title-link {
  padding: 2rem 2.5rem 1.9rem; }
  .accordion-list__item-title-link:hover {
    opacity: 1; }

.accordion-list__item.expanded > .accordion-list__item-title-link {
  opacity: 1; }

.accordion__content {
  padding-right: 0; }
  .accordion__content p:first-child {
    margin-top: 0; }
  .accordion__content p:last-child {
    margin-bottom: 2rem; }

.legend-title {
  letter-spacing: 1px;
  font-size: 1.65rem;
  font-weight: 700;
  padding-bottom: .75rem; }

.legend {
  display: flex;
  flex-direction: column; }
  .legend div {
    padding-bottom: 1rem; }

.legend-rows {
  display: flex;
  flex-direction: row;
  column-gap: 2rem;
  row-gap: 1rem; }
  @media screen and (max-width: 1438px) {
    .legend-rows {
      flex-direction: column; } }

.headline-h2 {
  margin-bottom: 3rem; }

@media screen and (max-width: 1168px) {
  .accordion-list__item {
    padding: 0 1rem 0 0; }
  .tactic-title {
    font-size: 18px; } }

@media screen and (max-width: 900px) {
  .column {
    padding-left: 0;
    padding-right: 0; }
    .column .container--padding-devices {
      padding-left: 0;
      padding-right: 0; } }

@media screen and (max-width: 599px) {
  .accordion-list__item {
    padding: 0 1rem 0 0; }
  .tactic-title {
    font-size: 18px;
    flex-direction: column;
    gap: 1rem; } }

.page__content {
  max-width: none; }

.content__inner {
  max-width: calc(78.125rem);
  margin-left: auto;
  margin-right: auto;
  padding-left: 0;
  padding-right: 0; }
  @media screen and (max-width: 900px) {
    .content__inner {
      max-width: none; } }

.hero .subheader {
  margin-bottom: 0; }

.hero .intro {
  font-size: 1.25rem;
  max-width: 49rem;
  margin-top: 2rem; }
  .hero .intro p {
    margin: 0; }

.text-photoset__list {
  flex-wrap: wrap;
  display: flex;
  justify-content: space-between;
  gap: 4rem; }

hr {
  border-top: 3px solid #000; }

.community-charts .chart {
  margin-bottom: 3rem; }

.community-charts canvas {
  height: auto !important;
  padding: 0 1.875rem; }

.community-charts .chart-title-h4 {
  text-transform: uppercase;
  font-weight: 700;
  background: #ffcd00;
  text-align: center;
  margin-top: 18px; }

.community-charts .legend-container li {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: stretch;
  margin: 1px 0 0;
  cursor: pointer;
  font-size: 14px;
  font-weight: bold; }
  .community-charts .legend-container li:nth-child(odd) {
    background-color: #f5f5f5; }
  .community-charts .legend-container li:nth-child(even) {
    background-color: #fafafa; }
  .community-charts .legend-container li p {
    padding: 0 5px;
    margin: 0;
    color: #000; }
    .community-charts .legend-container li p.value {
      width: 100%;
      margin: 0 5px;
      text-align: right; }
  .community-charts .legend-container li .legend-left {
    display: flex;
    align-items: center; }
  .community-charts .legend-container li .box-container {
    display: flex;
    border-right: 1px solid white; }
  .community-charts .legend-container li .value-container {
    display: flex;
    border-left: 1px solid white;
    width: 4.25rem;
    align-items: center; }
  .community-charts .legend-container li span {
    display: inline-block;
    flex-shrink: 0;
    height: 22px;
    width: 30px;
    margin: 5px;
    border-radius: 5px;
    border-width: 2px;
    border-style: solid; }

.community-charts .timestamp {
  text-align: right;
  margin-top: 2rem;
  margin-bottom: -2rem;
  font-size: .875rem; }

.feature-story .image-container picture {
  max-height: none; }

.feature-story .feature-photo {
  display: flex;
  justify-content: center;
  align-items: center; }
  .feature-story .feature-photo .photo-container {
    overflow: hidden;
    width: 100%;
    aspect-ratio: 16 / 12; }
  .feature-story .feature-photo span.lw_item_thumb {
    width: 100%; }
  .feature-story .feature-photo p {
    display: contents; }
  .feature-story .feature-photo picture.lw_image {
    display: inline; }
  .feature-story .feature-photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block; }

.feature-story .feature-text {
  display: flex;
  flex-direction: column;
  justify-content: center; }

.feature-story .feature-title-h3 {
  font-family: playfair-display-regular, "Times New Roman", serif;
  font-size: 2.75rem !important;
  margin-bottom: 30px;
  line-height: 1.25; }

.feature-story .lead-in {
  font-family: 'HK Grotesk', Arial, sans-serif;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.4;
  border-bottom: 3px solid #ffcd00; }

.grid-max-two-col .item-grid {
  max-width: 1000px; }

.nav-image {
  aspect-ratio: 1/1; }

.nav-image img {
  line-height: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: filter .3s; }

.nav-item:hover .nav-image img {
  filter: brightness(50%);
  transition: filter .3s; }

.nav-item {
  width: auto; }

@media (max-width: 350px) {
  .item-grid.nav-grid {
    grid-template-columns: 1fr; } }

p.nav-grid-label {
  font-size: 1.375rem;
  line-height: 1.25;
  margin-top: 0;
  margin-bottom: 0;
  font-weight: 700; }

.lw_image_caption {
  width: 100% !important; }

/* ---- Layout tokens (tweak as needed) ---- */
body.template-contained-leftnav {
  --container-max: 1280px;
  /* overall content width */
  --container-pad: clamp(16px, 4vw, 40px);
  /* side padding inside container */
  --nav-col: 215px;
  /* LEFT nav column width */
  --gap-col: 40px;
  /* space between nav and content */
  --hdr-h: 80px;
  /* sticky offset fallback; JS will update */
  --section-pad: 45px
; }

/* resets */
body.template-contained-leftnav .section {
  padding-top: var(--section-pad);
  padding-bottom: var(--section-pad); }

@media (max-width: 900px) {
  body.template-contained-leftnav .section {
    padding-top: 0; }
    body.template-contained-leftnav .section:not(:first-child) {
      padding-top: var(--section-pad); } }

body.template-contained-leftnav .section + .section {
  border-top: none; }

body.template-contained-leftnav hr {
  margin-top: 0 !important;
  margin-bottom: 0 !important; }

body.template-contained-leftnav .lw_widget > ul > li {
  margin: 0; }

/* Headline H3 — ~26–30px, below ~40px H2, above 18px body */
.headline-h3 {
  font-size: clamp(1.625rem, 2vw, 1.875rem);
  line-height: 1.25;
  font-weight: 700;
  letter-spacing: 0;
  margin: 0 0 0.35em;
  font-family: 'HK Grotesk', Arial, sans-serif; }

/* Headline H4 — ~22–26px */
.headline-h4 {
  font-size: clamp(1.375rem, 1.6vw, 1.625rem);
  line-height: 1.25;
  font-weight: 700;
  letter-spacing: 0;
  margin: 0 0 0.35em;
  font-family: 'HK Grotesk', Arial, sans-serif; }

/* Headline H5 — ~18–22px */
.headline-h5 {
  font-size: clamp(1.125rem, 1.25vw, 1.375rem);
  line-height: 1.3;
  /* a touch more for smaller sizes */
  font-weight: 700;
  letter-spacing: 0;
  margin: 0 0 0.35em;
  font-family: 'HK Grotesk', Arial, sans-serif; }

/*********************************************************************************
 * Template: contained left-nav + aligned sections (with robust nav fit handling)
 * Opt in by adding: <body class="template-contained-leftnav">
 *********************************************************************************/
/* ---- Colors ---- */
/* ---- Neutralize legacy container constraints on this template ---- */
body.template-contained-leftnav .page__content-wrapper,
body.template-contained-leftnav .page__content {
  flex-basis: auto;
  /* << your requested override */
  max-width: none;
  width: 100%;
  padding-left: 0;
  padding-right: 0; }

/* ---- Full-bleed bands (edge-to-edge; escape any parent container) ---- */
body.template-contained-leftnav .section--full-bleed {
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw); }

/* Optional centered shell inside a full-bleed band */
body.template-contained-leftnav .band {
  max-width: var(--container-max);
  margin: 0 auto;
  padding-inline: var(--container-pad); }

/* ---- Phantom grid to align hero/eyebrow to the left-nav/content column ---- */
body.template-contained-leftnav .band--align-left-nav {
  display: grid;
  grid-template-columns: var(--nav-col) var(--gap-col) minmax(0, 1fr);
  align-items: start; }

body.template-contained-leftnav .align-to-content-start {
  grid-column: 3; }

/* main content track */
body.template-contained-leftnav .align-to-nav-col {
  grid-column: 1; }

/* optional left track */
/* ---- Contained band (centered) ---- */
/* ---- Divider width matches content ---- */
:root {
  --divider-color: #e6e7e9;
  --divider-space: clamp(16px, 2vw, 32px);
  /* equal top/bottom spacing */ }

/* Divider aligned to the contained edge using --container-pad */
body.template-contained-leftnav hr.divider--contained {
  display: block;
  border: 0;
  border-top: 1px solid var(--divider-color);
  height: 0;
  /* equal spacing above/below */
  margin-block: var(--divider-space);
  /* align to the same inset as your contained sections */
  margin-top: 3rem !important;
  margin-left: 0;
  margin-right: var(--container-pad);
  width: auto;
  /* let it fill the remaining inline space */ }

/* If the divider sits inside a .section.section--contained,
   you can use the simpler version (no inline margins needed): */
.container .divider {
  border: 0;
  border-top: 1px solid var(--divider-color);
  height: 0; }

/* ---- Two-column grid: LEFT nav | content (contained band) ---- */
/* Pin columns explicitly */
/* ---- Critical grid overflow fix so children can shrink/scroll ---- */
/* ---- Sticky LEFT nav; reuse your existing classes ---- */
/* --- Lock sidebar geometry in this template --- */
/* When global toggles these body classes, still do NOT move the nav */
/* If global JS adds .fixed to #sidebar__inner, normalize in this template */
/* Header + footer blocks inside the sidebar */
/* ---- NAV LIST FIT STRATEGY ---- */
/* Default (desktop): show all items — no scroll */
/* Only on short viewports, allow scrolling as a fallback */
/* Compact mode (JS toggles .sidebar--compact if it barely overflows) */
/* Forced scroll mode (JS toggles .sidebar--scroll if still too tall) */
/* Keep only the current sub-branch open to save space (JS adds .is-open) */
body.template-contained-leftnav .lw_subnav {
  display: none; }

body.template-contained-leftnav li.is-open > .lw_subnav {
  display: block; }

/* Don’t duplicate the tablet dropdown on wide screens */
/* ---- Balance heights: keep content roughly ≈ nav height (optional) ---- */
/* If JS sets --nav-h, we use it; otherwise we fall back to viewport calc. */
body.template-contained-leftnav .layout--balanced-scroll .section__content {
  max-height: var(--nav-h, calc(100vh - var(--hdr-h) - 48px));
  overflow: auto;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch; }

/* ---- Constrained hero aligned to the same column as the nav band ---- */
body.template-contained-leftnav .section--contained.band--align-left-nav {
  display: grid;
  grid-template-columns: var(--nav-col) var(--gap-col) minmax(0, 1fr);
  align-items: start; }

body.template-contained-leftnav .hero--constrained {
  padding-top: 32px;
  padding-bottom: 24px; }

/* Title/intro in the hero should sit on the content track */
body.template-contained-leftnav .hero--constrained .align-to-content-start {
  grid-column: 3; }

/* ---- Responsive: stack columns and drop sticky in narrow viewports ---- */
@media (max-width: 1179px) {
  body.template-contained-leftnav .band--align-left-nav {
    display: block; }
  body.template-contained-leftnav .layout--balanced-scroll .section__content {
    max-height: none;
    overflow: visible; } }

/* Full-width title row (within the container), not aligned to the content column */
body.template-contained-leftnav .hero--fullwidth {
  /* uses the same contained width as other bands */
  max-width: var(--container-max);
  margin: 0 auto;
  padding-inline: var(--container-pad);
  padding-top: 32px;
  padding-bottom: 32px; }

/* Limit measure so the H1/lede don’t run too long */
body.template-contained-leftnav .hero--fullwidth .hero__content {
  max-width: 68ch;
  /* adjust to taste (or 720px) */ }

/* Make sure the vertical divider only appears in the nav row (already scoped) */
/* no border here */
/* If the hero still has .band--align-left-nav from older markup, neutralize it */
body.template-contained-leftnav .hero--fullwidth.band--align-left-nav {
  display: block;
  /* kill the phantom grid on the hero row */ }

body.template-contained-leftnav .hero--fullwidth.band--align-left-nav .align-to-content-start {
  grid-column: auto;
  padding-left: 0;
  /* no content-column indent for the hero */ }

/* Mobile stack: no special handling needed, but keep it explicit */
@media (max-width: 1179px) {
  body.template-contained-leftnav .hero--fullwidth {
    padding-top: 24px;
    padding-bottom: 12px; }
  body.template-contained-leftnav .hero--fullwidth .hero__content {
    max-width: none; } }

/*******************************
 * LEFT NAV — ZERO MOVEMENT + FULL-HEIGHT BAR
 * (Scoped to this template only)
 *******************************/
body.template-contained-leftnav {
  --nav-bar-w: 8px;
  /* ⬅️ adjust bar thickness (e.g., 4–10px) */
  --nav-gap: 16px;
  /* space between bar and text */
  --nav-gutter: calc(var(--nav-bar-w) + var(--nav-gap));
  /* stable left padding */
  --nav-row-pad-y: 8px;
  /* top/bottom padding for each link row */
  --nav-bar-dur: 360ms;
  /* slower than .18s */
  --nav-bar-ease: cubic-bezier(.22, 1, .36, 1);
  /* smooth “ease-out” */
  --nav-row-bg-hover: rgba(255, 209, 0, .08);
  --nav-row-bg-current: rgba(255, 209, 0, .12); }

/* Base: top-level links — geometry locked across all states */
body.template-contained-leftnav .page__sidebar .lw_widget_navigation > ul > li > a,
body.template-contained-leftnav .page__sidebar .lw_widget_navigation > ul > li > a:link,
body.template-contained-leftnav .page__sidebar .lw_widget_navigation > ul > li > a:visited,
body.template-contained-leftnav .page__sidebar .lw_widget_navigation > ul > li > a:hover,
body.template-contained-leftnav .page__sidebar .lw_widget_navigation > ul > li > a:focus,
body.template-contained-leftnav .page__sidebar .lw_widget_navigation > ul > li > a:active {
  display: block;
  position: relative;
  box-sizing: border-box;
  padding: var(--nav-row-pad-y) 0 var(--nav-row-pad-y) var(--nav-gutter) !important;
  /* constant */
  margin-left: 0 !important;
  border-left: 0 !important;
  transform: none !important;
  text-indent: 0 !important;
  font-weight: 400;
  /* avoid weight-jitter on hover */
  transition: color .15s ease, background-color .15s ease; }

/* FULL-HEIGHT yellow bar (no reflow) — applies to ALL levels */
body.template-contained-leftnav .page__sidebar .lw_widget_navigation ul li > a::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  /* full height of the anchor */
  bottom: 0;
  /* full height of the anchor */
  height: auto !important;
  /* ignore calc(100% - 7px) globals */
  width: var(--nav-bar-w, 8px) !important;
  background: #ffd100;
  border-radius: 0;
  /* set to 2px if you want rounded ends */
  opacity: 0;
  /* start hidden */
  transform: scaleY(0);
  /* start collapsed vertically */
  transform-origin: top;
  /* grow downwards */
  transition: transform var(--nav-bar-dur) var(--nav-bar-ease), opacity 150ms linear !important;
  /* keep fade snappy */
  will-change: transform;
  /* avoid fuzz on some GPUs */ }

/* States: show the bar (no lateral movement) */
body.template-contained-leftnav .page__sidebar .lw_widget_navigation ul li > a:hover::before,
body.template-contained-leftnav .page__sidebar .lw_widget_navigation ul li > a:focus-visible::before,
body.template-contained-leftnav .page__sidebar .lw_widget_navigation ul li.lw_current > a::before,
body.template-contained-leftnav .page__sidebar .lw_widget_navigation ul li.is-open > a::before {
  transform: scaleY(1);
  opacity: 1; }

/* Kill any li-level hover rules that nudge the link */
body.template-contained-leftnav .page__sidebar .lw_widget_navigation > ul > li:hover > a,
body.template-contained-leftnav .page__sidebar .lw_widget_navigation > ul > li:focus-within > a {
  padding-left: var(--nav-gutter) !important;
  margin-left: 0 !important;
  transform: none !important;
  border-left: 0 !important; }

/* Subnav: fixed indent, also zero movement */
body.template-contained-leftnav .page__sidebar .lw_widget_navigation ul.lw_subnav li > a {
  padding-left: calc(var(--nav-gutter) + 16px) !important;
  /* level 1 indent */ }

body.template-contained-leftnav .page__sidebar .lw_widget_navigation ul.lw_subnav ul.lw_subnav li > a {
  padding-left: calc(var(--nav-gutter) + 32px) !important;
  /* level 2 indent */ }

/* keep subnav closed unless .is-open is added by JS */
body.template-contained-leftnav .lw_subnav {
  display: none; }

body.template-contained-leftnav li.is-open > .lw_subnav {
  display: block; }

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  body.template-contained-leftnav .page__sidebar .lw_widget_navigation > ul > li > a,
  body.template-contained-leftnav .page__sidebar .lw_widget_navigation > ul > li > a::before {
    transition: none !important;
    transform: none !important; } }

/* Anchor box: stable padding so text never shifts (applies to all levels) */
body.template-contained-leftnav .page__sidebar .lw_widget_navigation ul li > a {
  position: relative;
  display: block;
  box-sizing: border-box;
  padding: var(--nav-row-pad-y, 8px) 0 var(--nav-row-pad-y, 8px) calc(var(--nav-bar-w, 8px) + var(--nav-gap, 16px)) !important; }

/* Hover / focus: show the row background tint */
body.template-contained-leftnav .page__sidebar .lw_widget_navigation ul li > a:hover,
body.template-contained-leftnav .page__sidebar .lw_widget_navigation ul li > a:focus-visible {
  background: var(--nav-row-bg-hover) !important;
  outline: none; }

/* Current/open branch: keep a slightly stronger tint */
body.template-contained-leftnav .page__sidebar .lw_widget_navigation ul li.lw_current > a,
body.template-contained-leftnav .page__sidebar .lw_widget_navigation ul li.is-open > a {
  background: var(--nav-row-bg-current) !important; }

/* Full-bleed tinted band */
body.template-contained-leftnav .section--tint {
  background: #f7f7f7; }

/* Contained content width & padding to match hero/contained bands */
body.template-contained-leftnav .section--tint .container {
  max-width: var(--container-max);
  margin: 0 auto;
  padding-inline: var(--container-pad);
  padding-block: 40px;
  /* adjust to taste */
  box-sizing: border-box; }

/* Optional: keep typography tidy inside the tint */
body.template-contained-leftnav .section--tint .section__content > *:first-child {
  margin-top: 0; }

body.template-contained-leftnav .section--tint .section__content > *:last-child {
  margin-bottom: 0; }

/* Tablet/mobile spacing tweak */
@media (max-width: 1179px) {
  body.template-contained-leftnav .section--tint .container {
    padding-block: 28px; } }

/* ---- section No 1 in Texas, ROI ---- */
/* Grid that aligns bands to the nav column */
body.template-contained-leftnav .band--align-left-nav {
  display: grid;
  grid-template-columns: var(--nav-col, 320px) var(--gap-col, 40px) minmax(0, 1fr);
  column-gap: var(--gap-col, 40px);
  align-items: start; }

/* Place children into the correct columns */
body.template-contained-leftnav .band--align-left-nav .align-to-nav-col {
  grid-column: 1; }

body.template-contained-leftnav .band--align-left-nav .section__content {
  grid-column: 3; }

/* Stat styling (left column) */
body.template-contained-leftnav .stat {
  display: grid;
  grid-template-columns: 1fr;
  row-gap: 6px;
  padding: 8px 0; }

body.template-contained-leftnav .stat__value {
  font-weight: 800;
  line-height: .9;
  letter-spacing: -0.02em;
  font-size: clamp(44px, 7vw, 80px);
  color: #ffcd00; }

body.template-contained-leftnav .stat__context {
  font-size: 1.5rem;
  font-weight: 700;
  text-transform: uppercase;
  color: #222;
  line-height: 1.3;
  max-width: 220px; }

/* Optional: subtle accent bar to tie to nav styling */
/* Responsive: stack at tablet */
@media (max-width: 1179px) {
  body.template-contained-leftnav .band--align-left-nav {
    display: block; }
  body.template-contained-leftnav .stat {
    margin-bottom: 16px; } }

/* knobs */
body.template-contained-leftnav {
  --tl-icon: 36px;
  /* icon box size */
  --tl-spine-x: 18px;
  /* center of 36px icon (36/2) */
  --tl-spine-w: 2px;
  --tl-spine: #efefef; }

/* spine behind the features */
body.template-contained-leftnav .stat-band .section__content .feature-list--timeline {
  position: relative;
  z-index: 0;
  /* create a stacking context */ }

body.template-contained-leftnav .stat-band .section__content .feature-list--timeline::before {
  content: "";
  position: absolute;
  left: var(--tl-spine-x);
  top: calc(var(--tl-icon) / 2);
  /* start halfway down the first icon */
  bottom: calc(var(--tl-icon) / 2);
  /* end halfway up the last icon */
  width: var(--tl-spine-w);
  background: var(--tl-spine);
  z-index: 0;
  /* keep it behind */ }

/* keep for the timeline version */
body.template-contained-leftnav .stat-band .section__content .feature-list--timeline .feature {
  position: relative;
  z-index: 1;
  /* sits above the spine (::before on the list) */
  border-top: 0;
  /* spine replaces row divider */
  padding: 20px 0;
  /* a touch more room; use 18–22px to taste */ }

/* items and content layered above the spine */
body.template-contained-leftnav .stat-band .section__content .feature-list--timeline .feature,
body.template-contained-leftnav .stat-band .section__content .feature-list--timeline .feature__body {
  position: relative;
  z-index: 1; }

/* icon is the node on the spine */
body.template-contained-leftnav .stat-band .section__content .feature-list--timeline .feature__icon {
  position: relative;
  z-index: 2;
  width: var(--tl-icon);
  height: var(--tl-icon);
  background: #fff;
  /* or #f7f7f7 inside a tinted band */
  box-shadow: 0 0 0 2px #ffd100 inset;
  /* SU gold ring */ }

/* Time chip: small, non-intrusive label */
body.template-contained-leftnav .stat-band .section__content .time-chip {
  display: inline-block;
  margin-left: 8px;
  padding: 2px 8px;
  font-size: .78rem;
  line-height: 1.2;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.05);
  color: #333;
  vertical-align: middle; }

/* Optional: emphasize current step on hover/focus */
body.template-contained-leftnav .stat-band .section__content .feature:hover .time-chip,
body.template-contained-leftnav .stat-band .section__content .feature:focus-within .time-chip {
  background: rgba(255, 209, 0, 0.25); }

/* Tablet: the spine still works; no changes required */
@media (max-width: 1179px) {
  body.template-contained-leftnav .stat-band .section__content .feature-list--timeline::before {
    left: 16px; } }

/* =============================
   Feature typography & spacing
   (right column in stat band)
   ============================= */
body.template-contained-leftnav .stat-band .section__content .feature__title {
  margin: 0 0 2px 0;
  font-weight: 700;
  font-size: 1.125rem;
  /* ~18px */
  line-height: 1.25;
  /* tight but readable */
  color: #111;
  display: inline-flex;
  gap: 8px;
  /* space before a time-chip, if present */
  align-items: baseline; }

body.template-contained-leftnav .stat-band .section__content .feature__text {
  margin: 0 0 8px 0;
  color: #333;
  max-width: 68ch;
  /* keep measure comfortable */ }

body.template-contained-leftnav .stat-band .section__content .feature__proof {
  margin: 0;
  /* proof sits tight to the text */ }

/* Proof badge (kept here for coherence; matches earlier style) */
body.template-contained-leftnav .stat-band .section__content .proof-badge {
  display: inline-block;
  font-size: .9rem;
  line-height: 1.2;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(255, 209, 0, 0.18);
  border: 1px solid #ffd100;
  color: #111;
  white-space: nowrap; }

/* Optional: links inside proof */
body.template-contained-leftnav .stat-band .section__content .proof-badge a {
  color: inherit;
  text-decoration: underline;
  text-underline-offset: 2px; }

/* Timeline extras (if using .feature-list--timeline) */
body.template-contained-leftnav .stat-band .section__content .feature-list--timeline .time-chip {
  display: inline-block;
  margin-left: 0;
  /* handled by title gap */
  padding: 2px 8px;
  font-size: .78rem;
  line-height: 1.2;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.05);
  color: #333;
  vertical-align: baseline; }

/* Hover/focus emphasis on the current item’s chip (optional) */
body.template-contained-leftnav .stat-band .section__content .feature-list--timeline .feature:hover .time-chip,
body.template-contained-leftnav .stat-band .section__content .feature-list--timeline .feature:focus-within .time-chip {
  background: rgba(255, 209, 0, 0.25); }

/* Responsive tweaks */
@media (max-width: 1179px) {
  body.template-contained-leftnav .stat-band .section__content .feature__title {
    font-size: 1.06rem; }
  body.template-contained-leftnav .stat-band .section__content .proof-badge {
    white-space: normal;
    /* allow wrap on smaller screens */ } }

/* if this band uses a gray background, soften the spine + match icon bg */
body.template-contained-leftnav .section--tint .feature-list--timeline::before {
  background: #e6e6e6; }

body.template-contained-leftnav .section--tint .feature__icon {
  background: #f7f7f7; }

/* === Launch Your Future ======================== */
.launch {
  /* aligns with contained page sections */
  padding-block: clamp(2rem, 5vw, 4rem);
  background: #fff;
  /* Pills */ }
  .launch .launch__inner {
    /* reuse your standard content width if you have a variable/class;
       otherwise a safe container: */
    max-width: 1280px;
    margin-inline: auto;
    padding-inline: var(--container-pad, 1.25rem); }
  .launch .launch__header {
    margin-bottom: clamp(1rem, 3vw, 1.75rem); }
  .launch .launch__title {
    /* subtle underline accent (Pirate Gold) to echo mockup) */
    position: relative; }
    .launch .launch__title::before {
      content: "";
      display: block;
      width: 88px;
      border-top: 3px solid var(--pirate-gold, #ffcd00);
      margin-top: .6rem; }
  .launch .launch__intro {
    color: var(--text-muted, #555);
    margin-top: .75rem;
    max-width: 56ch; }
  .launch .launch__grid {
    --gap: clamp(0.75rem, 2vw, 2rem);
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--gap);
    /*    @media (min-width: 1040px) {
      grid-template-columns: repeat(3, 1fr);
    }
      */ }
    @media (min-width: 1000px) {
      .launch .launch__grid {
        grid-template-columns: repeat(2, 1fr); } }
  .launch .launch-card {
    border: 1px solid rgba(0, 0, 0, 0.08);
    border-radius: 10px;
    padding: clamp(0.9rem, 2.2vw, 1.25rem);
    background: #fff;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
    transition: transform 220ms cubic-bezier(0.2, 0.7, 0.2, 1), box-shadow 220ms; }
    .launch .launch-card:hover, .launch .launch-card:focus-within {
      box-shadow: 0 6px 20px rgba(0, 0, 0, 0.08); }
  .launch .launch-card__title {
    font-size: clamp(1rem, 2vw, 1.5rem);
    margin: 0 0 .35rem;
    line-height: 1.25; }
  .launch .launch-card__copy {
    margin: 0 0 .8rem;
    color: var(--text-muted, #444);
    font-size: 1.125rem; }
  .launch .launch-card__pills {
    display: flex;
    flex-wrap: wrap;
    gap: .4rem .5rem; }
  .launch .pill {
    --h-pad: .7rem;
    display: inline-block;
    font-size: 1rem;
    line-height: 1;
    padding: 0.55rem var(--h-pad);
    border-radius: 999px;
    text-decoration: none;
    border: 1px solid transparent;
    font-weight: 600;
    white-space: nowrap;
    transition: background-color 160ms, color 160ms, border-color 160ms; }
    @media (max-width: 500px) {
      .launch .pill {
        font-size: .75rem; } }
  .launch .pill--gold {
    background: var(--pirate-gold, #ffcd00);
    color: #000;
    border-color: var(--pirate-gold, #ffcd00); }
    .launch .pill--gold:hover, .launch .pill--gold:focus {
      background: #e6b800;
      /* slightly darker hover */
      border-color: #e6b800;
      color: #000; }
  .launch .pill--gold--pale {
    background: rgba(255, 205, 0, 0.4);
    color: #4d3d00;
    border-color: rgba(255, 205, 0, 0.7); }
  .launch .pill--ghost {
    background: #fff;
    color: #000;
    border-color: rgba(0, 0, 0, 0.18); }
    .launch .pill--ghost:hover, .launch .pill--ghost:focus {
      border-color: rgba(0, 0, 0, 0.36); }

/* =========================================================
   Reusable Section Header
   Usage:
     <header class="su-header su-header--ruled">         // adds yellow rule
     <header class="su-header su-header--center">        // centers title/rule
     <header class="su-header su-header--compact">       // tighter spacing
   Elements:
     .su-header__title   -> put on your H2/H3; keep .headline-h2 if you use it
     .su-header__intro   -> optional short paragraph under title
   Theming via CSS vars:
     --su-rule-color, --su-rule-width, --su-rule-height
   ========================================================= */
.su-header {
  /* Defaults (inherit global colors/typography) */
  --su-rule-color: #ffcd00;
  /* PirateGold */
  --su-rule-width: 72px;
  --su-rule-height: 4px;
  margin: 0 0 1.25rem;
  /* Title */
  /* Intro text (optional) */
  /* Modifiers */
  /* Optional color variants if used on dark backgrounds */ }
  @media (min-width: 768px) {
    .su-header {
      margin-bottom: 1.5rem; } }
  .su-header .su-header__title {
    /* Keep your existing type scale by pairing with .headline-h2 on the element */
    margin: 0 0 .5rem;
    line-height: 1.15;
    font-weight: 700;
    /* aligns with LUF look; your .headline-h2 can override if needed */
    position: relative;
    /* Modifier: ruled underline */ }
    .su-header .su-header__title.is-ruled,
    .su-header--ruled .su-header .su-header__title {
      padding-bottom: .6rem; }
    .su-header .su-header__title.is-ruled::after,
    .su-header--ruled .su-header .su-header__title::after {
      content: "";
      position: absolute;
      left: 0;
      bottom: 0;
      width: var(--su-rule-width);
      height: var(--su-rule-height);
      background: var(--su-rule-color); }
  .su-header .su-header__intro {
    margin: 0;
    color: #555;
    max-width: 42rem;
    font-size: clamp(1rem, 1.2vw, 1.0625rem);
    line-height: 1.55; }
  .su-header.su-header--center {
    text-align: center; }
    .su-header.su-header--center .su-header__title::after {
      left: 50%;
      transform: translateX(-50%); }
    .su-header.su-header--center .su-header__intro {
      margin-left: auto;
      margin-right: auto; }
  .su-header.su-header--compact {
    margin-bottom: .75rem; }
    .su-header.su-header--compact .su-header__title {
      margin-bottom: .4rem; }
  .su-header.su-header--light .su-header__title {
    color: #fff; }
  .su-header.su-header--light .su-header__intro {
    color: rgba(255, 255, 255, 0.85); }
  .su-header.su-header--dark .su-header__title {
    color: #121212; }
  .su-header.su-header--dark .su-header__intro {
    color: #444; }

/* Optional: small entrance animation when scrolled into view */
@media (prefers-reduced-motion: no-preference) {
  .launch.is-visible [role="list"] > *:nth-child(2) {
    transition-delay: 60ms; }
  .launch.is-visible [role="list"] > *:nth-child(3) {
    transition-delay: 120ms; }
  .launch.is-visible [role="list"] > *:nth-child(4) {
    transition-delay: 180ms; }
  .launch.is-visible [role="list"] > *:nth-child(5) {
    transition-delay: 240ms; }
  .launch.is-visible [role="list"] > *:nth-child(6) {
    transition-delay: 300ms; } }

/* ==============================
   Split Band (50/50 media + text)
   ============================== */
/* ===== Split Band (50/50, outside edge matches site container, LiveWhale-safe) ===== */
.split-band {
  /* inner spacing near the image */
  --inset-pad: clamp(1.25rem, 3vw, 4rem);
  /* outer margin = (viewport - container)/2, never negative */
  --outer-margin: clamp(0px, (100vw - var(--container-max,1280px)) / 2, 9999px);
  /* OUTSIDE PAD = outer margin + container’s inner pad */
  --outside-pad: calc(var(--outer-margin) + var(--container-pad,16px));
  /* outside edge = OUTER MARGIN + CONTAINER PADDING */
  display: grid;
  grid-template-columns: 1fr;
  /* stacks on mobile */
  align-items: stretch;
  /* media height matches text height */
  gap: 0;
  margin-block: 2.5rem 3rem;
  /* Desktop: true 50/50 + outside edge aligned to container gutter */
  /* Optional: keep image edge-to-edge on mobile within contained pages */ }
  .split-band__media {
    position: relative;
    min-height: 240px;
    /* LiveWhale wrappers: make the whole chain fill the cell */
    /* Ensure cover behavior even if globals set img {height:auto !important} */ }
    .split-band__media > p {
      margin: 0;
      height: 100%; }
    .split-band__media .image-container,
    .split-band__media picture {
      display: block;
      width: 100%;
      height: 100%; }
    .split-band__media img,
    .split-band__media picture,
    .split-band__media video {
      display: block;
      width: 100% !important;
      height: 100% !important;
      /* force fill to crop to panel height */
      max-height: none !important;
      object-fit: cover;
      object-position: center; }
  .split-band__body {
    padding: var(--inset-pad);
    /* symmetric on mobile */
    display: flex;
    flex-direction: column;
    justify-content: center;
    /* Background variants */ }
    .split-band__body--bg-none {
      background: transparent; }
    .split-band__body--bg-light {
      background: #f3f3f3; }
    .split-band__body--bg-gold {
      background: var(--pirate-gold, #ffcd00);
      color: #000; }
    .split-band__body--bg-dark {
      background: #111;
      color: #fff; }
  @media (min-width: 900px) {
    .split-band {
      grid-template-columns: 1fr 1fr;
      /* hard 50/50 */ }
      .split-band .split-band__body {
        /* image side | outside edge (matches hero/Launch container) */
        padding-inline: var(--inset-pad) var(--outside-pad);
        padding-block: var(--inset-pad); }
      .split-band.split-band--reverse .split-band__media {
        order: 2; }
      .split-band.split-band--reverse .split-band__body {
        order: 1;
        /* outside edge | image side */
        padding-inline: var(--outside-pad) var(--inset-pad); } }
  .split-band.split-band--stack-edge .split-band__media {
    margin-inline: calc(50% - 50vw);
    width: 100vw; }

/* ==============================
   Testimonials (with Swiper.js)
   ============================== */
/* ===== Tokens & helpers ===== */
#testimonialsSwiper .swiper-pagination .swiper-pagination-bullet:focus-visible, #testimonialsSwiper .swiper-button-prev:focus-visible,
#testimonialsSwiper .swiper-button-next:focus-visible {
  outline: 2px solid currentColor;
  outline-offset: 2px; }

/* ===== Section ===== */
.section--testimonials {
  padding: 3rem 0; }
  @media (min-width: 768px) {
    .section--testimonials {
      padding: 4rem 0; } }
  .section--testimonials .container {
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 1rem; }
  .section--testimonials .section__header {
    margin-bottom: 1.25rem; }
  .section--testimonials .section__title {
    font-size: clamp(1.5rem, 2.5vw, 2.125rem);
    line-height: 1.2;
    margin: 0 0 .25rem; }
  .section--testimonials .section__intro {
    color: #555;
    max-width: 42rem; }
  .section--testimonials .testimonials-swiper {
    position: relative; }

/* ===== Testimonial card ===== */
.tcard {
  display: grid;
  gap: 1.25rem;
  align-items: center;
  justify-items: center;
  grid-template-columns: 1fr; }
  @media (min-width: 900px) {
    .tcard {
      grid-template-columns: 2fr 3fr; } }
  .tcard--center {
    text-align: center;
    max-width: 52rem;
    margin: 0 auto;
    display: grid;
    place-items: center;
    /* no-image layout fixes */
    grid-template-columns: 1fr; }
    @media (min-width: 900px) {
      .tcard--center {
        grid-template-columns: 1fr; } }
    .tcard--center .tcard__quote {
      padding-top: 0;
      grid-column: 1 / -1;
      max-width: 52rem; }
  .tcard__media {
    width: 100%; }
    .tcard__media img {
      display: block;
      width: 100%;
      aspect-ratio: 1;
      object-fit: cover;
      border-radius: 16px;
      box-shadow: 0 6px 18px rgba(0, 0, 0, 0.08); }
  .tcard__quote {
    font-size: clamp(1rem, 1.6vw, 1.125rem);
    line-height: 1.6;
    margin: 0; }
    .tcard__quote p {
      margin: 0; }
  .tcard__meta {
    margin-top: .75rem;
    font-size: .9375rem;
    color: #555; }

/* Safety: if a slide ends up with a single child, span full grid */
.tcard > :only-child {
  grid-column: 1 / -1; }

/* ===== Swiper (scoped) ===== */
#testimonialsSwiper {
  position: relative;
  overflow: hidden; }
  #testimonialsSwiper .tcard__media img {
    display: block;
    width: 100%;
    height: auto; }
  #testimonialsSwiper .tcard__quote {
    padding-top: .75rem; }
  #testimonialsSwiper .swiper-pagination {
    position: relative;
    margin-top: 1rem; }
    #testimonialsSwiper .swiper-pagination .swiper-pagination-bullet {
      width: 10px;
      height: 10px;
      opacity: .5; }
      #testimonialsSwiper .swiper-pagination .swiper-pagination-bullet-active {
        opacity: 1; }
  #testimonialsSwiper .swiper-button-prev,
  #testimonialsSwiper .swiper-button-next {
    color: #111;
    width: 44px;
    height: 44px;
    z-index: 2; }
    #testimonialsSwiper .swiper-button-prev:after,
    #testimonialsSwiper .swiper-button-next:after {
      font-size: 24px; }
  @media (prefers-reduced-motion: reduce) {
    #testimonialsSwiper .swiper-wrapper {
      transition-duration: .25s !important; } }

/* ===== Reusable Card Grid ===== */
:root {
  --card-gap-x: 50px;
  --card-gap-y: 72px;
  /* try 72px if you want 8pt rhythm */ }

.section .su-header + .card-grid {
  margin-top: 32px; }

@media (max-width: 1024px) {
  :root {
    --card-gap-x: 24px;
    --card-gap-y: 48px; } }

@media (max-width: 640px) {
  :root {
    --card-gap-x: 16px;
    --card-gap-y: 28px; }
  .section .su-header + .card-grid {
    margin-top: 24px; } }

.card-grid {
  display: grid;
  column-gap: var(--card-gap-x, 32px);
  row-gap: var(--card-gap-y, 72px);
  --cols: 1;
  grid-template-columns: repeat(var(--cols), 1fr);
  margin: 0;
  padding: 0;
  list-style: none; }
  @media (min-width: 860px) {
    .card-grid {
      --cols: 2; } }

/* 1) Make cards equal height inside the grid */
.card-grid > .card {
  display: flex;
  flex-direction: column;
  /* media on top, body below */ }

/* 2) Ensure the media doesn't steal extra space */
.card__media {
  flex: 0 0 auto; }

.card__media p {
  margin: 0; }

/* your markup wraps the picture in a <p> */
/* 3) Stack the body vertically and push the button down */
.card__body {
  display: flex;
  flex-direction: column;
  gap: .75rem;
  /* space between title, text, button */
  flex: 1 1 auto;
  /* take remaining height so we can push the button */ }

/* 4) Pin the button to the bottom of the card body */
.card__body .btn {
  margin-top: auto;
  /* <- does the magic */
  align-self: flex-start;
  /* keep button left-aligned (optional) */ }

/* small internal balance so rows don't feel more spaced than card content */
.card .card__body {
  padding-bottom: 1.25rem; }

/* Section seam before grey band */
.section + .section.split-band--50-50,
.section + .section.section--light {
  /* whatever class your grey band uses */
  margin-top: 16px;
  /* or add 16px to previous section’s bottom padding */ }

/* ===== Reusable Card ===== */
.card {
  background: #f6f6f6;
  border: 1px solid rgba(0, 0, 0, 0.08);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.05); }

/* Only apply stretched-link behavior outside the LiveWhale editor */
body:not(.lw_editor_on) {
  /* Base card context */
  /* --- Fallback (no :has) — stretch first link unless opted out --- */
  /* --- Modern path using :has() (will be ignored by non-supporting browsers) --- */
  /* Remove fallback overlay when a .btn[href] exists… */
  /* …and make the first .btn[href] the stretched link */
  /* --- Keep secondary controls interactive (above overlay) --- */
  /* …except the actual stretched link (both paths) */
  /* --- Focus & hover affordances --- */
  /* --- Per-card opt-out --- */ }
  body:not(.lw_editor_on) .card {
    position: relative;
    isolation: isolate;
    overflow: clip; }
  @supports not (overflow: clip) {
    body:not(.lw_editor_on) .card {
      overflow: hidden; } }
  body:not(.lw_editor_on) .card:not(.card--no-stretch) a[href]:not(.not-stretched-link):first-of-type {
    position: static; }
  body:not(.lw_editor_on) .card:not(.card--no-stretch) a[href]:not(.not-stretched-link):first-of-type::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: auto;
    background: transparent; }
  body:not(.lw_editor_on) .card:not(.card--no-stretch):has(.btn[href]) a[href]:not(.not-stretched-link):first-of-type::after {
    content: none; }
  body:not(.lw_editor_on) .card:not(.card--no-stretch):has(.btn[href]) .btn[href]:not(.not-stretched-link):first-of-type {
    position: static; }
  body:not(.lw_editor_on) .card:not(.card--no-stretch):has(.btn[href]) .btn[href]:not(.not-stretched-link):first-of-type::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: auto;
    background: transparent; }
  body:not(.lw_editor_on) .card :is(.btn, [role="button"], button, input, select, textarea),
  body:not(.lw_editor_on) .card a[href] {
    position: relative;
    z-index: 2; }
  body:not(.lw_editor_on) .card:not(.card--no-stretch) a[href]:not(.not-stretched-link):first-of-type {
    z-index: auto; }
  body:not(.lw_editor_on) .card:not(.card--no-stretch):has(.btn[href]) .btn[href]:not(.not-stretched-link):first-of-type {
    z-index: auto; }
  body:not(.lw_editor_on) .card:has(a[href]:focus-visible) {
    box-shadow: 0 0 0 3px var(--focus-ring, rgba(255, 204, 0, 0.45)); }
  body:not(.lw_editor_on) a[href]:focus-visible {
    outline: 3px solid var(--focus-ring, rgba(255, 204, 0, 0.8));
    outline-offset: 3px; }
  body:not(.lw_editor_on) .card--no-stretch a[href]::after {
    content: none !important; }

.card__media {
  /* choose a default ratio; change via modifier below */
  aspect-ratio: 4/3;
  position: relative; }
  .card__media:empty {
    background: #c83a8c; }

/* Optional ratios */
.card__media--16x9 {
  aspect-ratio: 16/9; }

.card__media--1x1 {
  aspect-ratio: 1/1; }

/* Make LiveWhale media fill & crop */
.media-cover > p {
  margin: 0;
  height: 100%; }

.media-cover .image-container,
.media-cover picture {
  display: block;
  width: 100%;
  height: 100%; }

.media-cover img,
.media-cover picture,
.media-cover video {
  width: 100%;
  height: 100% !important;
  object-fit: cover;
  display: block; }

.card__body {
  padding: clamp(1rem, 2.5vw, 1.25rem); }

/* Card title = same font as .su-header__title, one step smaller */
.card__title {
  margin: 0 0 .35rem; }

/* If h3.su-header__title already exists, keep it.
   Add a dedicated “card size” modifier for reuse anywhere. */
.su-header__title--card {
  /* one step down from your h3.su-header__title */
  font-size: clamp(1.625rem, 2vw, 1.875rem);
  /* 26px → 30px */
  line-height: 1.25;
  font-weight: 700;
  /* ensure same weight; drop if inherited */ }

.card__text {
  margin: 0 0 .85rem;
  color: #333;
  font-size: clamp(1rem, 1.9vw, 1.125rem);
  line-height: 1.45; }

/* ==============================
   Section: Where Are They Now
   ============================== */
/* Section tint like the mockup */
.where-now {
  background: #f7f7f7; }

/* Card grid: site-wide default was 2-up; this modifier goes 3-up on wide */
/* 3-up layout for this grid */
@media (min-width: 1000px) {
  .card-grid--3up {
    --cols: 3; } }

.card-grid--3up .card {
  display: flex;
  flex-direction: column;
  /* ensures equal height when parent stretches items */
  height: 100%; }

.card-grid--3up .card__content {
  /* body fills remaining space */
  flex: 1 1 auto;
  /* Center text in these cards */
  text-align: center;
  display: flex;
  flex-direction: column;
  padding: clamp(1rem, 2.5vw, 1.25rem);
  /* space between title/desc/link if present */
  gap: .5rem; }

.card-grid--3up .card__body {
  text-align: center; }

.card-grid--3up .card__footer {
  /* pushes link to bottom of the card */
  margin-top: auto;
  text-align: center; }

.card-grid--3up .card__link {
  display: inline-flex; }

/* Full-bleed tint for "Where Are They Now?" */
.where-now {
  background: #f3f3f3;
  /* force the section to span the viewport width */
  margin-inline: calc(50% - 50vw);
  width: 100vw;
  /* keep the contained padding rhythm */
  padding-inline: var(--container-pad, 24px); }

/* Don’t double the inner padding—let the container size itself */
/* Cards in this section are clean and compact */
.where-now .card {
  background: #fff;
  border: 1px solid rgba(0, 0, 0, 0.08);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.05); }

/* ==============================
   Logo Strip (flexbox version)
   ============================== */
.logo-grid {
  --logo-gap: 48px;
  --logo-max-w: 140px;
  --logo-max-h: 100px;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: var(--logo-gap);
  margin: clamp(24px, 5vw, 56px) 0 0;
  padding: 0;
  list-style: none; }

.logo-grid .logo {
  /* allow each logo to grow up to the target width, then wrap */
  flex: 0 1 var(--logo-max-w);
  display: flex;
  align-items: center;
  justify-content: center; }

.logo-grid img {
  display: block;
  max-width: var(--logo-max-w);
  max-height: var(--logo-max-h);
  width: auto;
  height: auto;
  object-fit: contain;
  filter: grayscale(100%);
  opacity: .9; }

/* ==============================
   Section: Stories (with Swiper.js)
   ============================== */
/* ===========================
   Stories Swiper (full-bleed)
   =========================== */
@media (max-width: 640px) {
  :root {
    --card-gap: 16px; } }

.section--stories {
  padding: 3rem 0;
  /* Full-bleed track with container-aligned gutters */ }
  .section--stories .stories-bleed {
    width: 100vw;
    position: relative;
    left: 50%;
    right: 50%;
    margin-left: -50vw;
    margin-right: -50vw;
    /* Sass-safe “max(var(--container-pad), 16px)” */
    padding-inline: clamp(16px, var(--container-pad, 16px), 9999px); }
  .section--stories .stories-swiper {
    position: relative;
    /* Swiper spacing aligns with grid gap when centered */
    /* Multiple visible cards; tune sizes as needed */
    /* When there aren't enough slides to overflow, center them and mimic gap */
    /* Story card visuals and padding (keeps image edge-to-edge) */
    /* -------- Arrows -------- */
    /* Desktop/tablet: arrows live in the gutters (don’t cover content) */
    /* Mobile: overlay the arrows slightly inside the media area to save space */
    /* Hidden when not needed (toggled by JS when row doesn’t overflow) */ }
    .section--stories .stories-swiper .swiper-wrapper {
      align-items: stretch; }
    .section--stories .stories-swiper .swiper-slide {
      flex: 0 0 auto;
      width: clamp(240px, 28vw, 360px);
      /* desktop/tablet */ }
    @media (max-width: 640px) {
      .section--stories .stories-swiper {
        /* mobile peek */ }
        .section--stories .stories-swiper .swiper-slide {
          width: clamp(240px, 85vw, 360px); } }
    .section--stories .stories-swiper.is-centered .swiper-wrapper {
      justify-content: center;
      gap: var(--card-gap); }
    .section--stories .stories-swiper .story-card {
      --card-pad: 1rem;
      /* 16–20px usually feels right */
      background: #fff;
      border: 1px solid #ddd;
      border-radius: 0;
      overflow: hidden;
      /* rounds the image corners */ }
      .section--stories .stories-swiper .story-card .card__linkwrap {
        display: block;
        color: inherit;
        text-decoration: none; }
      .section--stories .stories-swiper .story-card .card__body {
        padding: 0.75rem var(--card-pad); }
      .section--stories .stories-swiper .story-card .card__title {
        margin: 0; }
      .section--stories .stories-swiper .story-card .card__text {
        margin-top: .45rem;
        color: #555; }
    .section--stories .stories-swiper .swiper-button-prev,
    .section--stories .stories-swiper .swiper-button-next {
      position: absolute;
      top: 50%;
      transform: translateY(-50%);
      width: 44px;
      height: 44px;
      /* 44px tap target */
      border-radius: 999px;
      background: rgba(255, 255, 255, 0.95);
      box-shadow: 0 6px 20px rgba(0, 0, 0, 0.18);
      z-index: 2; }
    .section--stories .stories-swiper .swiper-button-prev {
      left: clamp(16px, var(--container-pad, 16px), 9999px); }
    .section--stories .stories-swiper .swiper-button-next {
      right: clamp(16px, var(--container-pad, 16px), 9999px); }
    .section--stories .stories-swiper .swiper-button-prev:focus-visible,
    .section--stories .stories-swiper .swiper-button-next:focus-visible {
      outline: 2px solid #000;
      outline-offset: 2px; }
    @media (hover: hover) {
      .section--stories .stories-swiper .swiper-button-prev:hover,
      .section--stories .stories-swiper .swiper-button-next:hover {
        box-shadow: 0 10px 28px rgba(0, 0, 0, 0.24); } }
    @media (max-width: 640px) {
      .section--stories .stories-swiper .swiper-button-prev,
      .section--stories .stories-swiper .swiper-button-next {
        top: 30%;
        left: auto;
        right: auto;
        background: rgba(255, 255, 255, 0.95); }
      .section--stories .stories-swiper .swiper-button-prev {
        left: 8px; }
      .section--stories .stories-swiper .swiper-button-next {
        right: 8px; } }
    .section--stories .stories-swiper.hide-arrows .swiper-button-prev,
    .section--stories .stories-swiper.hide-arrows .swiper-button-next {
      display: none; }

/* ==============================
   Buttons
   ============================== */
.btn {
  /* Layout */
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  text-transform: uppercase;
  /* Shape & sizing */
  padding: .875rem 1.25rem;
  /* ~14px/20px */
  border: 2px solid transparent;
  line-height: 1;
  font-weight: 700;
  font-size: clamp(0.9375rem, 0.9vw, 1rem);
  /* 15px → 16px */
  text-decoration: none;
  cursor: pointer;
  /* Motion & focus */
  transition: background-color .15s ease, color .15s ease, border-color .15s ease, filter .15s ease, transform .06s ease;
  /* Optional icon in buttons */
  /* Disabled */
  /* Respect reduced motion */ }
  .btn:focus-visible {
    outline: 2px solid #000;
    /* visible on gold */
    outline-offset: 2px; }
  .btn .icon,
  .btn svg {
    width: 1.1em;
    height: 1.1em;
    flex: 0 0 auto; }
  .btn:disabled, .btn[aria-disabled="true"] {
    opacity: .6;
    cursor: not-allowed;
    pointer-events: none; }
  @media (prefers-reduced-motion: reduce) {
    .btn {
      transition: none; } }

/* Gold (Pirate Gold) button */
.btn--gold {
  --_gold: var(--pirate-gold, #ffcd00);
  background: var(--_gold);
  border-color: var(--_gold);
  color: #000; }
  @media (hover: hover) and (pointer: fine) {
    .btn--gold:hover {
      filter: brightness(0.95); } }
  .btn--gold:focus-visible {
    /* stronger ring against gold */
    box-shadow: 0 0 0 3px rgba(0, 0, 0, 0.25); }

/* Ghost (outline) button */
.btn--ghost {
  background: transparent;
  color: #000;
  border-color: currentColor; }
  @media (hover: hover) and (pointer: fine) {
    .btn--ghost:hover {
      background: var(--pirate-gold, #ffcd00);
      border-color: var(--pirate-gold, #ffcd00);
      color: #000; } }
  .btn--ghost:focus-visible {
    box-shadow: 0 0 0 3px rgba(0, 0, 0, 0.25); }

/* Ghost on dark backgrounds */
.btn--ghost-on-dark {
  color: #fff;
  border-color: rgba(255, 255, 255, 0.9); }
  @media (hover: hover) and (pointer: fine) {
    .btn--ghost-on-dark:hover {
      background: var(--pirate-gold, #ffcd00);
      border-color: var(--pirate-gold, #ffcd00);
      color: #000; } }
  .btn--ghost-on-dark:focus-visible {
    /* stronger ring on dark */
    box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.45); }

/* 4px gold outline, white bg, black text */
.btn--outline-gold {
  --_gold: var(--pirate-gold, #ffcd00);
  background: #fff;
  color: #000;
  border: 4px solid var(--_gold); }
  @media (hover: hover) and (pointer: fine) {
    .btn--outline-gold:hover {
      background: var(--_gold);
      color: #000; } }
  .btn--outline-gold:focus-visible {
    box-shadow: 0 0 0 3px rgba(0, 0, 0, 0.25); }

/* Small button helper (reusable) */
.btn--sm {
  padding: .55rem .9rem;
  font-size: .8125rem;
  border-width: 2px; }

/* ==============================
   Card Link 
   ============================== */
/* Gold-ruled text link used in cards */
.card__link {
  --gold: var(--pirate-gold, #ffcd00);
  display: inline-flex;
  align-items: center;
  gap: .6rem;
  font-weight: 700;
  color: #000;
  text-decoration: none;
  line-height: 1.1;
  margin-top: auto;
  font-size: 16px;
  text-transform: uppercase;
  /* pushes to bottom if flex column */ }
  .card__link::before {
    content: "";
    width: 18px;
    height: 4px;
    border-radius: 2px;
    background: var(--gold);
    flex: 0 0 auto; }
  @media (hover: hover) and (pointer: fine) {
    .card__link:hover {
      color: #979797; } }
  .card__link:focus-visible {
    outline: 2px solid #000;
    outline-offset: 2px; }
  .card__link.link--loose {
    margin-bottom: 3rem;
    margin-top: -.5rem; }

.text-media--middle .card__link.link--loose {
  margin-bottom: 0; }

/* ==============================
   Section: Full-Bleed Background
   ============================== */
/* Base: sections are full-width */
.section {
  width: 100%; }

/* The actual container */
.container,
.container {
  /* allow either name during transition */
  max-width: var(--container-max, 1280px);
  margin-inline: auto;
  padding-inline: var(--container-pad, 24px); }

/* Full-bleed background while content stays contained */
.section--bleed-bg {
  background: var(--section-bg, #f3f3f3);
  /* make the background span the viewport */
  /* keep container rhythm on the edges */ }

/* avoid double padding on inner wrapper */
/* grid header */
:root {
  --nav-w: 400px;
  /* sidebar width */
  --gap-col: 0;
  /* space between nav & content (0 or 20px) */
  --content-max: 1280px;
  /* max width of the centered content column */
  --divider-color: #e6e6e6; }

/* Ensure the outer container doesn’t constrain this band */
body.template-contained-leftnav .layout-left-nav .container {
  display: block;
  max-width: none;
  margin: 0;
  padding: 0; }

/* =======================
   Band frame (DEFAULT, wide screens)
   3 cols: [left gutter ≥ nav] | [centered content ≤ 1280] | [right gutter ≥ nav]
   ======================= */
.layout-left-nav .page-frame {
  display: grid;
  grid-template-columns: minmax(var(--nav-w), 1fr) minmax(0, var(--content-max)) minmax(0, 1fr);
  /* right gutter mirrors left for true centering - unclear */
  align-items: start;
  width: 100%;
  padding-inline: var(--container-pad, 1rem); }

/* Sidebar lives in the left gutter and hugs the content edge */
.layout-left-nav .page-frame > .page__sidebar {
  grid-column: 1;
  grid-row: 1 / -1;
  /* span the band rows */
  width: var(--nav-w);
  justify-self: end;
  /* push sidebar to the gutter’s right edge */
  margin-right: var(--gap-col);
  /* visible gap between nav and content */
  position: relative;
  border: 0 !important;
  padding-right: 0 !important;
  box-shadow: none !important; }

/* Divider between nav and content (no layout impact) */
/* Content column (centered track) + wrapping guard */
.layout-left-nav .page-frame > .page__right {
  grid-column: 2;
  min-width: 0;
  /* critical for wrapping inside grid */
  position: relative;
  z-index: 1; }

/* =======================
   Tight width: drop the right gutter (nav + content only)
   Trigger when viewport < content-max + 2*nav + horizontal padding
   ======================= */
/* Tight width: drop the right gutter (nav + content only) */
/* =======================
   Mobile stack
   ======================= */
@media (max-width: 900px) {
  .layout-left-nav .page-frame {
    grid-template-columns: 1fr; }
  .layout-left-nav .page-frame > .page__sidebar {
    grid-column: 1;
    justify-self: start;
    width: auto;
    margin-right: 0;
    margin-top: 0; }
  .layout-left-nav .page-frame > .page__sidebar::after {
    display: none; }
  .layout-left-nav .page-frame > .page__right {
    grid-column: 1; } }

.page__hero .intro {
  max-width: 48ch; }

/* =======================
   Full-bleed background helper for bands
   ======================= */
.section--bleed-bg {
  margin-inline: calc(50% - 50vw);
  padding-inline: var(--container-pad, 1rem);
  background: var(--section-bg, transparent); }

/* =======================
   Defensive: wrappers not acting as the band frame do nothing special
   ======================= */
.page__content-wrapper:not(.page-frame) {
  position: static !important;
  display: block !important;
  overflow: visible !important;
  inset: auto !important; }

/* Cap the visual height and crop the overflow */
.header-hero-container .image-container {
  /* Adjust these to taste */
  --min: 240px;
  --ideal: 80vh;
  --max: 900px;
  height: clamp(var(--min), var(--ideal), var(--max));
  overflow: hidden;
  position: relative; }
  @media (max-width: 600px) {
    .header-hero-container .image-container {
      /* Adjust 600px to your desired breakpoint */
      --ideal: 50vh;
      /* Phone value */ } }

/* Make the image fill that capped box and crop gracefully */
.header-hero-container .image-container img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 50% 25%;
  display: block; }

/* ==============================
   Section: Text Tiles
   ============================== */
/* Text-only tiles on a full-width light gray band */
.text-tiles {
  /* spacing tokens */
  --tile-gap: clamp(16px, 2.5vw, 32px);
  --tile-pad-block: clamp(16px, 2.5vw, 28px);
  --tile-max: 65ch;
  /* comfortable measure for paragraphs */
  /* optional: keep consistent inner padding if your container doesn't already */
  /* Tighten typical section hierarchy */ }
  .text-tiles .section__inner {
    padding-inline: var(--container-pad, 1rem); }
  .text-tiles__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--tile-gap); }
    @media (min-width: 900px) {
      .text-tiles__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)); } }
  .text-tiles__item {
    /* “card-like” rhythm without card chrome */
    padding-block: var(--tile-pad-block);
    max-width: var(--tile-max); }
  .text-tiles h3 {
    margin: 0 0 0.35em; }
  .text-tiles p {
    margin: 0 0 0.9em; }

/* 3-across variant */
.text-tiles--3 {
  /* slightly tighter spacing for smaller tiles */
  --tile-gap: clamp(16px, 2.2vw, 50px);
  --tile-pad-block: clamp(12px, 2vw, 24px); }
  .text-tiles--3 .text-tiles__grid {
    /* default: 1 col (mobile) already in base */ }
    @media (min-width: 720px) {
      .text-tiles--3 .text-tiles__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)); } }
    @media (min-width: 1100px) {
      .text-tiles--3 .text-tiles__grid {
        grid-template-columns: repeat(3, minmax(0, 1fr)); } }
  .text-tiles--3 .text-tiles__item {
    /* narrower measure since we’re 3-up; keeps it airy */
    max-width: 55ch; }

/* Simple CTA link with round arrow pip (brandable) */
/* Respect LiveWhale editor (no big reflows if you want) */
/*
body.lw_editor_on .text-tiles__grid { display: block; }
body.lw_editor_on .text-tiles__item { padding-block: 12px; }
*/
/* ==============================
   Section: Text + Media
   ============================== */
.text-media {
  --gap-mobile: clamp(20px, 4vw, 32px);
  /* tighter when stacked */
  --gap-desktop: clamp(32px, 3vw, 40px);
  /* NEW: separate caps for stacked vs. desktop */
  --img-max-mobile: min(100%, 720px);
  --img-max-desktop: clamp(280px, 36vw, 520px);
  --img-radius: 0;
  /* tweak if you want rounded */
  /* Image */
  /* Text */
  /* comfortable line length */ }
  .text-media__grid {
    display: grid;
    align-items: start;
    gap: var(--gap-mobile);
    grid-template-columns: 1fr;
    /* stacked by default */ }
    @media (min-width: 900px) {
      .text-media__grid {
        grid-template-columns: minmax(0, auto) minmax(0, 1fr);
        gap: var(--gap-desktop); } }
  .text-media__media {
    margin: 0;
    justify-self: center;
    /* centered when stacked */ }
    .text-media__media img {
      display: block;
      width: 100%;
      max-width: var(--img-max-mobile);
      /* grows when stacked */
      height: auto;
      border-radius: var(--img-radius); }
    @media (min-width: 900px) {
      .text-media__media {
        justify-self: start;
        /* left-justified on desktop */ }
        .text-media__media img {
          width: var(--img-max-desktop);
          /* constrain on desktop */
          max-width: none; } }
  .text-media__caption {
    font-size: .875rem;
    color: #555;
    margin-top: .5rem; }
  .text-media__body {
    max-width: 70ch; }
  .text-media__body > h2 {
    margin: 0 0 .35em; }
  .text-media__body > p {
    margin: 0 0 .9em; }

/* Vertically center the media and text on desktop */
@media (min-width: 900px) {
  .text-media--middle .text-media__grid {
    align-items: center; } }

/* belt-and-suspenders: ensure both children obey */
@media (min-width: 900px) {
  .text-media--middle .text-media__media,
  .text-media--middle .text-media__body {
    align-self: center; } }

/* Reuse the CTA pill from earlier; include if not already present */
/* Light gray band with white “card” wrapper */
.text-media-card {
  /* the gray comes from section--bleed-bg via --section-bg inline */
  /* Optional: tighten spacing between media/text inside the card on mobile */ }
  .text-media-card__inner {
    background: #fff;
    border: 1px solid var(--card-border, #e7e7e7);
    border-radius: 12px;
    padding: clamp(1.25rem, 3vw, 2rem);
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.06); }
  .text-media-card .text-media {
    --img-radius: 0;
    /* keep PNG edges crisp on white */ }
  .text-media-card.make-appointment .text-media-card__inner {
    border-radius: 4px; }
  .text-media-card.make-appointment .btn {
    font-size: 1.125rem; }
  @media screen and (min-width: 600px) {
    .text-media-card.make-appointment .btn {
      font-size: 1.25rem; } }
  .text-media-card.make-appointment p {
    font-size: 1.25rem;
    text-align: center; }

/* Editor-safe: tone down chrome inside LiveWhale editor if desired */
/* Text + Button variant (piggybacks on text-media structure) */
.text-button {
  /* tune gaps globally; override per-instance via --gap-* */
  --gap-mobile: clamp(20px, 4vw, 32px);
  --gap-desktop: clamp(48px, 6vw, 96px);
  /* increased desktop gap */
  /* mobile: stack */
  /* allow shrink without overflow */
  /* keep CTA on one line; prevent layout push */
  /* optional: nudge sizing inside the make-appointment card */ }
  .text-button .text-media__grid {
    grid-template-columns: 1fr;
    gap: var(--gap-mobile);
    align-items: center; }
  @media (min-width: 900px) {
    .text-button {
      /* hug right edge if desired */ }
      .text-button .text-media__grid {
        /* left flexes; right sizes to single-line CTA */
        grid-template-columns: minmax(0, 1fr) max-content;
        gap: var(--gap-desktop); }
      .text-button .text-media__body:last-child {
        justify-self: end; } }
  .text-button .text-media__body {
    min-width: 0; }
  .text-button .btn {
    display: inline-block;
    white-space: nowrap;
    /* force single line */
    max-inline-size: 100%;
    /* safety on very small widths */
    overflow: hidden;
    /* truncate if absurdly long */
    text-overflow: ellipsis;
    /* graceful truncation */
    text-align: center; }
  .text-button.make-appointment p {
    font-size: 1.125rem; }
  .text-button.make-appointment .btn {
    font-size: 1.125rem; }

/* ==============================
   Breadcrumb fixes
   ============================== */
.page__hero {
  margin-block: 0; }

.breadcrumbs {
  padding-left: 0;
  padding-top: 0; }

.lw_breadcrumb_link, .lw_breadcrumb_link a {
  font-size: 17px;
  color: #000; }

.hide-breadcrumbs .breadcrumbs, .hide-breadcrumbs .sidebar__inner {
  transform: none; }

/* turn off the existing before-slash */
/* add the slash after each crumb except the last */
/* 1) Kill old separators */
.lw_breadcrumb_separator {
  display: none; }

.lw_breadcrumb_link:nth-of-type(n+2)::before {
  content: none; }

/* 2) Don't break inside a crumb */
.lw_breadcrumb_link,
.lw_breadcrumb_link a,
.lw_breadcrumb_link.lw_current {
  white-space: nowrap; }

/* 3) Attach the slash to the END of the previous crumb.
      Wrap is allowed AFTER the slash (at the following space). */
.lw_breadcrumb_link:not(:last-child)::after {
  content: "/ "; }

/* 4) Safety: avoid mid-word wrapping anywhere in the trail */
.breadcrumbs__list {
  word-break: keep-all;
  overflow-wrap: normal; }

/* Hide the built-in separators */
.lw_breadcrumb_separator {
  display: none; }

.lw_breadcrumb_link:nth-of-type(n+2)::before {
  content: none; }

/* Keep each crumb's text intact, but allow breaks BETWEEN crumbs */
.lw_breadcrumb_link a,
.lw_breadcrumb_link.lw_current {
  white-space: nowrap;
  /* don't break inside the text */ }

/* Add the slash to the END of each crumb except the last.
   Because it's on the SPAN (which is breakable), a line can break after it. */
.lw_breadcrumb_link:not(:last-child)::after {
  content: "/";
  /* you can do "/\2009" for thin space after */
  margin: 0 .35ch 0 .35ch;
  /* spacing around the slash */ }

/* Optional: keep words intact, no emergency hyphenation */
.breadcrumbs__list {
  word-break: keep-all;
  overflow-wrap: normal; }

.breadcrumbs__list {
  display: flex;
  flex-wrap: wrap;
  gap: .35ch;
  align-items: baseline; }

.lw_breadcrumb_link {
  display: inline-flex; }

/* ==============================
   left nav fixes
   ============================== */
/* Default: flows with the page (no internal scrolling) */
.sidebar__inner {
  position: static;
  top: auto;
  left: auto;
  width: auto;
  height: auto;
  overflow: visible;
  padding: 15px 20px 30px 50px;
  padding: 0 20px 0 0; }

/* When the hero scrolls out (JS adds .fixed), make it sticky/fixed */
/* Keep your existing mobile overrides as-is */
@media (max-width: 900px) {
  .sidebar__inner {
    position: static;
    width: 100%;
    height: auto;
    overflow: visible;
    padding: 0 0 10px; } }

.sidebar {
  display: flex;
  flex-direction: column;
  flex-grow: 1;
  flex-basis: 320px;
  align-self: stretch;
  max-width: 320px;
  padding-left: 50px; }

.breadcrumbs {
  display: block; }

@media (max-width: 900px) {
  .breadcrumbs {
    display: none; }
  .sidebar {
    display: block;
    position: static;
    width: 100%;
    flex-basis: 100%;
    max-width: 100%;
    height: auto;
    padding-top: 10px;
    padding-left: 0;
    padding-right: 25px;
    transition: none; }
  .layout-left-nav .page-frame > .page__sidebar {
    width: 100%; }
  .sidebar__list {
    display: none; }
  .show-on-tablets.dropdown {
    display: flex; } }

/* ==============================
   Section: Hero with Rankings
   ============================== */
/* Base */
.hero {
  position: relative; }

.hero__content {
  display: grid;
  grid-template-columns: 1fr; }

/* === Two-col: text | rankings (desktop) === */
.hero__content.hero--with--sidebar {
  display: grid;
  grid-template-columns: minmax(0, 1fr) clamp(220px, 28vw, 360px);
  grid-template-areas: "text ranks";
  column-gap: clamp(16px, 3vw, 40px);
  align-items: start; }

.hero__content.hero--with--sidebar > :first-child {
  grid-area: text;
  min-width: 0; }

.hero__content.hero--with--sidebar > :last-child {
  grid-area: ranks;
  min-width: 0;
  justify-self: end;
  align-self: start;
  /* remove width:max-content; it fights shrink/wrap */ }

/* Rankings block */
.hero__stats {
  position: static;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  text-align: right;
  pointer-events: none;
  /* inner links still clickable */
  margin-top: 70px; }

.rank {
  pointer-events: auto;
  display: inline-flex;
  flex-direction: column;
  gap: .35rem; }

.rank__value {
  font-size: 5rem;
  line-height: 1; }

.rank__context {
  font-size: 1.25rem;
  text-transform: uppercase; }

/* Animation/stagger (unchanged) */
.rankings [data-rank] {
  --rank-shift: clamp(24px, 6vw, 56px);
  opacity: 0;
  transform: translateX(var(--rank-shift)) scale(0.985);
  transition: transform 360ms cubic-bezier(0.2, 0.7, 0.2, 1), opacity 360ms; }

.rankings.is-visible [data-rank] {
  opacity: 1;
  transform: translateX(0) scale(1); }

.rankings.is-visible [data-rank]:nth-child(1) {
  transition-delay: 80ms; }

.rankings.is-visible [data-rank]:nth-child(2) {
  transition-delay: 220ms; }

@media (max-width: 480px) {
  .rankings [data-rank] {
    --rank-shift: clamp(16px,5vw,32px);
    transition-duration: 280ms; } }

@media (prefers-reduced-motion: reduce) {
  .rankings, .rankings [data-rank] {
    transition: none !important;
    transform: none !important;
    opacity: 1 !important; } }

/* Rankings typography */
.rank__value {
  font-family: var(--font-serif, "Libre Caslon Text", serif);
  font-weight: 700;
  line-height: 1;
  /* keep big desktop size but scale on smaller screens */
  font-size: 5rem;
  color: var(--pirate-gold, #ffcd00); }

.rank__context {
  font-weight: 600;
  text-transform: uppercase;
  color: var(--main-charcoal, #111);
  /* allow wrapping on small screens; stays tighter on desktop */
  font-size: 1.25rem;
  white-space: normal; }

/* tokens (adjust to your system) */
:root {
  --content-max: 1280px; }

/* Center and contain the inner grid */
.page__hero .hero__content {
  box-sizing: border-box;
  max-width: var(--content-max);
  width: 100%; }

/* Make the right column only as wide as its content */
.hero__content.hero--with--sidebar {
  display: grid;
  grid-template-columns: fit-content(80ch) fit-content(clamp(220px, 28vw, 360px));
  column-gap: clamp(16px, 3vw, 40px);
  align-items: start; }

.hero__content.hero--with--sidebar > * {
  min-width: 0; }

.hero__content.hero--with--sidebar > :last-child {
  justify-self: end; }

/* Desktop-wide (≥1400px): two columns with rankings */
@media (min-width: 1900px) {
  .hero__content.hero--with--sidebar {
    display: grid;
    grid-template-columns: fit-content(80ch) fit-content(clamp(220px, 28vw, 360px));
    column-gap: clamp(16px, 3vw, 40px);
    align-items: start; }
  .hero__content.hero--with--sidebar > :last-child {
    justify-self: start;
    /* keeps it close to the text */
    display: block; } }

/* Under 1400px: hide rankings and collapse to a single column */
@media (max-width: 1899px) {
  .hero__content.hero--with--sidebar {
    grid-template-columns: 1fr; }
  .hero__content.hero--with--sidebar > :last-child {
    display: none;
    /* removes the right column entirely */ } }

/* Make the right column only as wide as its content */
/* Hug the text column */
.hero__content.hero--with--sidebar > :last-child {
  justify-self: start;
  /* ← you added this — keep it */
  align-self: start;
  margin: 0;
  /* no extra offset */ }

/* Remove artificial spacing inside the rankings block */
.hero__stats {
  margin-top: 0; }

/* If you want it even tighter on very wide screens */
.livewhale .sidebar__inner {
  margin-top: 0;
  padding-top: 0; }

.page__sidebar .lw_widget_navigation ul li a {
  font-size: 1rem; }

#page-title {
  max-width: 25ch; }

section.hero {
  padding-bottom: 0 !important; }

.sidebar__menu {
  margin-bottom: 1.5rem; }

@media screen and (max-width: 900px) {
  .under-nav-contact {
    display: none; } }

.where-now .card__content {
  background: #f3f3f3; }

/* WHERE-NOW slider: circular avatars + fixed slide height */
.section.section--testimonials {
  /* tune these if needed */
  --wn-avatar: 300px;
  /* Card layout for consistent vertical rhythm */
  /* Circular avatar wrapper */
  /* Placeholder state (when no image found) */
  /* Optional: keep body from collapsing on short content */ }
  .section.section--testimonials .testimonials-swiper {
    /* force a consistent slide height (we’ll disable autoHeight in JS) */ }
    .section.section--testimonials .testimonials-swiper .swiper-slide {
      height: var(--wn-slide-h);
      display: flex;
      /* to center the wn-card vertically if desired */
      align-items: stretch; }
  .section.section--testimonials .wn-card {
    display: grid;
    grid-template-rows: auto 1fr;
    gap: clamp(12px, 2.5vw, 16px);
    width: 100%; }
  .section.section--testimonials .wn-card__avatar {
    width: var(--wn-avatar);
    aspect-ratio: 1;
    /* keeps square box */
    border-radius: 999px;
    /* circle */
    overflow: hidden;
    /* clip image to circle */
    background: #f3f3f3;
    /* neutral when no photo */
    display: grid;
    place-items: center;
    margin-bottom: 0.25rem;
    /* Any <img> or <picture> > img inside */ }
    .section.section--testimonials .wn-card__avatar img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      /* fills circle */
      display: block; }
  .section.section--testimonials .wn-card__avatar.is-placeholder {
    /* Option A: show initials via data-initials attribute */ }
    .section.section--testimonials .wn-card__avatar.is-placeholder::after {
      content: attr(data-initials);
      font-weight: 700;
      font-size: clamp(18px, 4.5vw, 28px);
      line-height: 1;
      color: #888; }
  .section.section--testimonials .wn-card__body {
    display: grid;
    align-content: start;
    min-height: 0;
    /* allows content to shrink within fixed slide height */ }

/* If your headshot lives in an existing media block (e.g., .card__media),
   you can make it circular without new markup:
   .section.where-now .card__media { width: var(--wn-avatar); aspect-ratio:1; border-radius:999px; overflow:hidden; }
   .section.where-now .card__media img { width:100%; height:100%; object-fit:cover; }
*/
.section.section--testimonials .tcard__media {
  width: var(--wn-avatar);
  aspect-ratio: 1;
  border-radius: 999px;
  overflow: hidden; }

.section.section--testimonials .tcard__media img {
  width: 100%;
  height: 100%;
  object-fit: cover; }

.section--testimonials {
  --arrow-size: 44px;
  --arrow-outset: clamp(12px, 4vw, 56px);
  /* Lock to edges, then shift outward */
  /* Mobile: keep them inside */ }
  .section--testimonials .testimonials-swiper,
  .section--testimonials .testimonials-swiper .swiper {
    position: relative;
    /* a positioning context is still good */
    /* overflow can stay hidden if you must; transform doesn’t get clipped by the buttons themselves */
    overflow: visible; }
  .section--testimonials .swiper-button-prev,
  .section--testimonials .swiper-button-next {
    position: absolute;
    top: 50%;
    width: var(--arrow-size);
    height: var(--arrow-size);
    z-index: 5; }
  .section--testimonials .swiper-button-prev {
    left: 0;
    transform: translate(calc(-100% - var(--arrow-outset)), -50%); }
  .section--testimonials .swiper-button-next {
    right: 0;
    transform: translate(calc(100% + var(--arrow-outset)), -50%); }
  @media (max-width: 700px) {
    .section--testimonials .swiper-button-prev {
      transform: translate(0, -50%);
      left: 8px; }
    .section--testimonials .swiper-button-next {
      transform: translate(0, -50%);
      right: 8px; } }

.sidebar__content {
  padding-bottom: 0; }

/* Icon cards */
.card--icon {
  /* tune these in one place */
  --icon-size: clamp(56px, 9vw, 96px);
  --icon-color: #f7f7f7;
  /* icon line color */
  --icon-bg: #424242;
  /* media background */
  --icon-ring: rgba(0,0,0,.06);
  /* subtle ring */ }
  .card--icon .card__media {
    display: grid;
    place-items: center;
    background: radial-gradient(closest-side, var(--icon-ring), transparent 70%), var(--icon-bg); }
  .card--icon .card__icon {
    width: var(--icon-size);
    height: var(--icon-size);
    color: var(--icon-color);
    /* crisp strokes on all screens */
    shape-rendering: geometricPrecision;
    vector-effect: non-scaling-stroke; }

.card--icon {
  --icon-size: 112px; }

/* ==============================
   Dropdown relabeling (mobile nav)
   ============================== */
@media (max-width: 900px) {
  .sidebar__title {
    display: none; } }

/* Prevent FOUC below 901px */
.sidebar__social {
  margin-top: 10px; }

.icon-links a,
.icon-links a:hover,
a.icon-link,
a.icon-link:hover {
  border-bottom: none;
  transition: none; }

h1, h2 {
  display: inline-block;
  /* Ensures the :before element positions correctly */
  position: relative;
  /* Establishes a positioning context for the :before pseudo-element */
  margin-top: 20px;
  padding-top: 20px; }

h1:before, h2:before {
  content: "";
  /* Must be present for :before to display */
  display: block;
  /* Makes the bar take up its own line */
  height: 5px;
  /* Adjust the thickness of the bar */
  background-color: #ffcd00;
  /* Set the color */
  position: absolute;
  /* Take it out of the normal flow */
  top: 0;
  /* Position it at the very top of the H1/H2 element */
  left: 0;
  /* **FLUSH LEFT to the H1/H2's left edge** */ }

h1:before {
  width: 325px; }

h2:before {
  width: 75px; }
