/* Theme base styles */

/* Tools
Any animations, or functions used throughout the project.
Note: _macros.css needs to be imported into each stylesheet where macros are used and not included here
*/

/* Generic
This is where reset, normalize & box-sizing styles go.
*/

*, *:before, *:after {
  box-sizing: border-box;
}
/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */

/* Document
   ========================================================================== */

/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 */

html {
  line-height: 1.15; /* 1 */
  -webkit-text-size-adjust: 100%; /* 2 */
}

/* Sections
   ========================================================================== */

/**
 * Remove the margin in all browsers.
 */

body {
  margin: 0;
}

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */

h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

/* Grouping content
   ========================================================================== */

/**
 * Add the correct box sizing in Firefox.
 */

hr {
  box-sizing: content-box;
  height: 0;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */

pre {
  font-family: monospace, monospace; /* 1 */
  font-size: 1em; /* 2 */
}

/* Text-level semantics
   ========================================================================== */

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, Opera, and Safari.
 */

abbr[title] {
  border-bottom: none; /* 1 */
  text-decoration: underline; /* 2 */
  text-decoration: underline dotted; /* 2 */
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */

b,
strong {
  font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */

code,
kbd,
samp {
  font-family: monospace, monospace; /* 1 */
  font-size: 1em; /* 2 */
}

/**
 * Add the correct font size in all browsers.
 */

small {
  font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/* Forms
   ========================================================================== */

/**
 * 1. Change the font styles in all browsers.
 * 2. Remove the margin in Firefox and Safari.
 */

button,
input,
optgroup,
select,
textarea {
  font-family: inherit; /* 1 */
  font-size: 100%; /* 1 */
  line-height: 1.15; /* 1 */
  margin: 0; /* 2 */
}

/**
 * Remove the inheritance of text transform in Edge and Firefox.
 * 1. Remove the inheritance of text transform in Firefox.
 */

button,
select { /* 1 */
  text-transform: none;
}

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */

button,
[type="button"],
[type="reset"],
[type="submit"] {
  -webkit-appearance: button;
}

/**
 * Remove the inner border and padding in Firefox.
 */

button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

/**
 * Restore the focus styles unset by the previous rule.
 */

button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

/**
 * Correct the padding in Firefox.
 */

fieldset {
  padding: 0.35em 0.75em 0.625em;
}

/**
 * Remove the padding so developers are not caught out when they zero out `fieldset` elements in all browsers.
 */

legend {
  padding: 0;
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */

progress {
  vertical-align: baseline;
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */

[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
  height: auto;
}

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */

[type="search"] {
  -webkit-appearance: none; /* 1 */
  /* outline-offset: -2px; /* 2 */
}

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */

[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */

::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}

/* Interactive
   ========================================================================== */

/*
 * Add the correct display in Edge and Firefox.
 */

details {
  display: block;
}

/*
 * Add the correct display in all browsers.
 */

summary {
  display: list-item;
}

/* Objects
Non-cosmetic design patterns including grid and layout classes)
*/



/* CSS variables */

:root {
  --column-gap: 2.13%;
  --column-width-multiplier: 8.333;
}

/* Mobile layout */

.row-fluid {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
}


  .row-fluid .span1,
  .row-fluid .span2,
  .row-fluid .span3,
  .row-fluid .span4,
  .row-fluid .span5,
  .row-fluid .span6,
  .row-fluid .span7,
  .row-fluid .span8,
  .row-fluid .span9,
  .row-fluid .span10,
  .row-fluid .span11,
  .row-fluid .span12{
  min-height: 1px;
  width: 100%;
}

/* Desktop layout */

@media (min-width: 768px) {
  .row-fluid {
    flex-wrap: nowrap;
    justify-content: space-between;
  }

  
    .row-fluid .span1 {
      width: calc(var(--column-width-multiplier) * 1% * 1 - var(--column-gap) * (11 * var(--column-width-multiplier) / 100));
    }
  
    .row-fluid .span2 {
      width: calc(var(--column-width-multiplier) * 1% * 2 - var(--column-gap) * (10 * var(--column-width-multiplier) / 100));
    }
  
    .row-fluid .span3 {
      width: calc(var(--column-width-multiplier) * 1% * 3 - var(--column-gap) * (9 * var(--column-width-multiplier) / 100));
    }
  
    .row-fluid .span4 {
      width: calc(var(--column-width-multiplier) * 1% * 4 - var(--column-gap) * (8 * var(--column-width-multiplier) / 100));
    }
  
    .row-fluid .span5 {
      width: calc(var(--column-width-multiplier) * 1% * 5 - var(--column-gap) * (7 * var(--column-width-multiplier) / 100));
    }
  
    .row-fluid .span6 {
      width: calc(var(--column-width-multiplier) * 1% * 6 - var(--column-gap) * (6 * var(--column-width-multiplier) / 100));
    }
  
    .row-fluid .span7 {
      width: calc(var(--column-width-multiplier) * 1% * 7 - var(--column-gap) * (5 * var(--column-width-multiplier) / 100));
    }
  
    .row-fluid .span8 {
      width: calc(var(--column-width-multiplier) * 1% * 8 - var(--column-gap) * (4 * var(--column-width-multiplier) / 100));
    }
  
    .row-fluid .span9 {
      width: calc(var(--column-width-multiplier) * 1% * 9 - var(--column-gap) * (3 * var(--column-width-multiplier) / 100));
    }
  
    .row-fluid .span10 {
      width: calc(var(--column-width-multiplier) * 1% * 10 - var(--column-gap) * (2 * var(--column-width-multiplier) / 100));
    }
  
    .row-fluid .span11 {
      width: calc(var(--column-width-multiplier) * 1% * 11 - var(--column-gap) * (1 * var(--column-width-multiplier) / 100));
    }
  
}
.content-wrapper {
  margin: 0 auto;
  padding: 0;
}

@media screen and (min-width: 1380px) {
  .content-wrapper {
    padding: 0;
  }
}

.dnd-section > .row-fluid {
  margin: 0 auto;
}

.dnd-section, .dnd-column {
  padding: 0;
}


@media (max-width: 767px) {
  .dnd-section, .dnd-column {
    padding: 0;
  }
}

/* Elements
Base HTML elements are styled in this section (<body>, <h1>, <a>, <p>, <button> etc.)
*/

/* The overflow-wrap is meant to prevent long/large words from breaking the mobile responsiveness of a page (e.g. horizontal scrolling). It is preferred to reduce font sizes on mobile to address this, with this CSS specifically helping with extreme scenarios where a reduction in font size is not possible. */

body {
  line-height: 1.5;
  overflow-wrap: break-word;
  background-color: #F5F5F5;
}

table {
  line-height: 1.25;
}

/* Handles word breaking for a few specific languages which handle breaks in words differently. If your content is not translated into these languages, you can safely remove this.  */

html[lang^="ja"] body,
html[lang^="zh"] body,
html[lang^="ko"] body {
  line-break: strict;
  overflow-wrap: normal;
  word-break: break-all;
}


/* Paragraphs */

p {
 margin-top: 0.75rem;
 margin-bottom: 0;
}

.tswCaptionFirstLine {
  margin-top: 0.5rem;
}

.tswCaption + .tswCaption {
  margin-top: 0;
}

.tswBlogPostCardSummary {
  margin-top: 0.25rem;
}

table + .tswAccentHeading, table + p + .tswAccentHeading {
  margin-top: 1.5rem;
}

h2 ~ p {
  margin-left: 1rem;
}

h3 ~ p {
  margin-left: 1rem;
}

.tswThreeColText > h3 ~ p, .tswTwoColImgCardContents > h3 ~ p, .tswFlipFlopRow > h3 ~ p, .tswBlogPostCardTitle ~ p {
  margin-left: 0;
}

h4 ~ p {
  margin-left: 2rem;  
}

.tswSectionContents > h4 ~ p {
  margin-left: 1rem;
}

.tswBorderedSection > p:first-child, .tswBorderedSectionSidebar > p:first-child, .tswBorderedSection > div > p:first-child, .tswImgCaption > p {
  margin-top: 0;
}

/* Anchors */

a {
  cursor: pointer;
}

/* Headings */

h1 {
  text-align: center;
  line-height: 1.1;
}

@media (min-width:767px){
  h1 {
    margin: 1rem 5rem;
    line-height: 1.35;
  }
}

.tswDifferentClass {
  font-size: 4rem;
}

h2 {
  margin: 0.75rem 0 0;
}

.tswBorderedSection > h2 {
  margin-top: 0;
}

h3 {
  margin: 0.75rem 0 0;
}

.tswThreeColText:first-child > h3, .tswFlipFlopRow > h3 {
  margin-top: 0;
}

@media (min-width:767px) {
  .tswThreeColText > h3:first-child, .tswTwoColImgCardContents > h3:first-child {
    margin-top: 0;
  }
}

.tswSectionHeadline {
  margin-top: 0;
}

.tswBlogPostCardTitle {
  margin-top: 0;
}

h4,
h5,
h6 {
  margin: 0.75rem 0 0 1rem;
}

.tswSectionContents > h4 {
  margin-left: 0;
}

/* Lists */

.tswThreeColumns {
  column-count: 3; 
  column-rule: 2px solid #F05C5C;
  list-style-type: none;
}

ol {
  margin: 0;
  padding-inline-start: 0;
  margin-top: 0.5rem;
  margin-left: 1.5rem;
}

ol li {
  margin-top: 0.5rem;
  padding-left: 0.5rem;
}

ul {
  margin: 0.75rem 0 0;
  padding-left: 0;
  list-style-type: none;
}

ul.no-list {
  list-style: none;
  margin: 0;
}

ul.tswNoGapList {
  margin: 0 0 0;
}

ul.tswSidebarList {
  display: inline-block;
  text-align: left;
}

ul ul,
ol ul,
ul ol,
ol ol {
  margin: 0;
}

main ul li {
  margin: 0.25rem 0 0 1rem;
  position: relative;
  padding-left: 1.25rem;
}

td ul li {
  margin-left: 0;
}

.tswSidebarList li {
  margin-left: 0;
  margin-top: 0.75rem;
}

main ul li::before {
  content: url(https://241954041.fs1.hubspotusercontent-na2.net/hubfs/241954041/raw_assets/public/thesaltyworm/images/tswIcons/tswBullet.svg);
  display: inline-block;
  position: absolute;
  left: 0;
  width: 0.65rem;
  margin: 0 0.2rem;
}

.tswSidebarList li::before {
  content: "*";
}

li > ul > li::before {
  content: "-";
}

li > ul > li > ul > li::before {
  content: "◦";
}

  
.tswPhotoIncluded::before {
  margin: 0 11rem;
}

li > p {
  margin: 0.35rem 0 0;
}

.tswSidebarList li > p {
  margin: 0.15rem 0 0;
}

/* Code blocks */

pre {
  overflow: auto;
}

code {
  vertical-align: bottom;
}

/* Blockquotes */

blockquote {
  border-left: 2px solid;
  margin: 0 0 1.4rem;
  padding-left: 0.7rem;
}

/* Horizontal rules */

hr {
  border: none;
  border-bottom: 1px solid #CCC;
}

/* Image alt text */

img {
  font-size: 0.583rem;
  word-break: normal;
}
button,
.button,
.hs-button {
  cursor: pointer;
  display: inline-block;
  text-align: center;
  transition: all 0.15s linear;
  white-space: normal;
}

button:disabled,
.button:disabled,
.hs-button:disabled {
  background-color: #D0D0D0;
  border-color: #D0D0D0;
  color: #E6E6E6;
}

/* No button */

.no-button,
.no-button:hover,
.no-button:focus,
.no-button:active {
  background: none;
  border: none;
  border-radius: 0;
  color: initial;
  font-family: inherit;
  font-size: inherit;
  font-style: inherit;
  font-weight: inherit;
  letter-spacing: inherit;
  line-height: inherit;
  margin-bottom: 0;
  padding: 0;
  text-align: left;
  text-decoration: none;
  transition: none;
}
/* Fields */

.hs-form-field {
  margin-bottom: 1.4rem;
}

/* Labels */

form label {
  display: block;
  font-size: 1rem;
  margin-bottom: 0.35rem;
}

/* Form Title */
.form-title {
  margin-bottom: 0;
}

/* Help text */

form legend {
  font-size: 0.875rem;
}

/* Inputs */

form input[type=text],
form input[type=search],
form input[type=email],
form input[type=password],
form input[type=tel],
form input[type=number],
form input[type=file],
form select,
form textarea {
  display: inline-block;
  font-size: 1rem;
  width: 100%;
}

form input[type=text]:focus,
form input[type=search]:focus,
form input[type=email]:focus,
form input[type=password]:focus,
form input[type=tel]:focus,
form input[type=number]:focus,
form input[type=file]:focus {
			
	outline: #F05C5C;
	border-color: #F05C5C;
}

form textarea {
  resize: vertical;
}

form fieldset {
  max-width: 100% !important;
}

/* Inputs - checkbox/radio */

form .inputs-list {
  margin: 0;
  padding: 0;
  list-style: none;
}

form .inputs-list > li {
  display: block;
  margin: 0.7rem 0;
}

form .inputs-list input,
form .inputs-list span {
  vertical-align: middle;
}

form input[type=checkbox],
form input[type=radio] {
  cursor: pointer;
  margin-right: 0.35rem;
}

/* Inputs - date picker */

.hs-dateinput {
  position: relative;
}

.hs-dateinput:before {
  content:'\01F4C5';
  position: absolute;
  right: 10%;
  top: 50%;
  transform: translateY(-50%);
}

.fn-date-picker .pika-table thead th {
  color: #FFF;
}

.fn-date-picker td.is-selected .pika-button {
  border-radius: 0;
  box-shadow: none;
}

.fn-date-picker td .pika-button:hover,
.fn-date-picker td .pika-button:focus {
  border-radius: 0 !important;
  color: #FFF;
}

/* Inputs - file picker */

form input[type=file] {
  background-color: transparent;
  border: initial;
  padding: initial;
}

/* Headings and text */

form .hs-richtext,
form .hs-richtext p {
  font-size: 0.875rem;
  margin: 0 0 1.4rem;
}

form .hs-richtext img {
  max-width: 100% !important;
}

/* GDPR */

.legal-consent-container .hs-form-booleancheckbox-display > span,
.legal-consent-container .hs-form-booleancheckbox-display > span p {
  margin-left: 1rem !important;
}

/* Validation */

.hs-form-required {
  color: #EF6B51;
}

.hs-input.invalid.error {
  border-color: #EF6B51;
}

.hs-error-msg {
  color: #EF6B51;
  margin-top: 0.35rem;
}

/* Submit button */

form input[type=submit],
form .hs-button {
  cursor: pointer;
  display: inline-block;
  text-align: center;
  transition: all 0.15s linear;
  white-space: normal;
}

/* Captcha */

.grecaptcha-badge {
  margin: 0 auto;
}


  /* Search button input field and suggestions */
  .body-container-wrapper .hs-search-field__button {
    padding: 15px;
  }

  .body-container-wrapper .hs-search-field__bar--button-inline .hs-search-field__button {
    margin-left: 6px;
    margin-bottom: 0;
  }

  .body-container-wrapper .hs-search-field__button svg {
    height: 15px;
    fill: #fff;
  }

  .body-container-wrapper .hs-search-field__bar > form > .hs-search-field__input {
    padding: 10px;
  }

  .body-container-wrapper .hs-search-field__suggestions li a {
    color: #494A52;
    padding: 0.35rem 0.7rem;
    text-decoration: none;
    transition: background-color 0.3s;
  }

/* Table */

table {
  table-layout: fixed;
  border: none;
  border-collapse: collapse;
  margin-bottom: 0.25rem;
  margin-top: 1rem;
  overflow-wrap: break-word;
  font-size: 0.9rem;
  margin-left: -0.75rem;
}

@media (min-width:767px){
  
  table {
    width: 65%;
    font-size: 1.1rem;
  } 
  
  .tswSectionGridMain table {
     margin-top: 0;
     margin-left: 0;
  } 
}


/* Column Widths */

.tswNightsOrTimeCol {
    width: 15%;
}

.tswLocationCol {
    width: 35%;
}

.tswWideCol {
    width: 35%;
}

.tswNarrowCol {
    width: 15%;
}


.tswTotalCol {
    width: 15%;
}

.tswNotesCol {
    width: 15%;
}

/* Table cells */
 
th,
td {
  vertical-align: middle;
  text-align: center;
  padding: 0.15rem;
  border-top: 0.05rem solid;
  border-right: 0.05rem solid;
  border-color: #F05C5C;
}



th:last-child,
td:last-child {
    border-right: none;
}

tr:first-child th {
  border-top: none;
}


/* Table header */

thead th {
  vertical-align: bottom;
  font-weight: 400;
}

/*Table Contents */

td > p {
  margin: 0;
}

td > ul {
  margin: 0;
  padding: 0;
}

/* Components
Specific pieces of UI that are stylized. Typically used for global partial styling
*/

/* @import url('http://example.com/example_style.css'); */

/***********************************************/
/* CSS @imports must be at the top of the file */
/* Add them above this section                 */
/***********************************************/

/*****************************************/
/* Start your style declarations here    */
/*****************************************/



/*

1. Text Formatting
2. Figure & Figcaptions
3. Sections
4a. Three Column Text
4b. Flip Flop Rows
5a. Three Column Images (Food Reviews)
5b. Images in Three Column Text
5c. Images in Portrait Image Bar
6. Two Column Image Cards
7. Image Grid Settings
8. Selected Images
9. Blog Post Cards
10. Button Icons
11. Expand & Collapse
12. Popups

*/



/* 1. Text Formatting */

.tswInlineText {
  display: inline;
}

.tswInlineNoteContainer {
  margin-top: 0.75rem;
  padding-left: 40px;
}

.tswTextDivider {
  color: #F05C5C;
  font-weight: 600;
}

.tswAccentText {
  font-family: Tenor Sans;
  font-size: 0.75rem;
  text-transform: uppercase;
}

.tswAccentHeading {
  font-family: Tenor Sans;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
}

.tswSidebarHeading {
  color: #F05C5C;
  font-size: 1.275rem;
  font-weight: 400;
}

.tswMiniHeading {
  font-weight: 400;
  font-size: 0.9rem;
}

.tswMiniText {
  font-size: 0.9rem;
}

.tswDividerLeft {
  border-left: 3px solid #F05C5C;
  padding-left: 0.25rem;
}

.tswDividerRight {
  border-right: 3px solid #F05C5C;
  padding-right: 0.25rem;
}

.tswEmphasisText {
  color: #F05C5C;
  font-weight: 400;
}

.tswPostscript  {
  border-top: 2px solid #CED4DB;
  margin-top: 1rem;
}

.tswDesktopBreak {
  display: none;
}

@media (min-width:767px){
  
  .tswMobileBreak {
      display: none;
  }
  
  .tswDesktopBreak {
      display: block;
  }
  
  .tswDividerRight {
      padding-right: 0;
      margin-right: 0.22rem;
  }
}



/* 2. Figure / Figcaptions */

figure {
  display: table;
  margin: 0;
}

.tswTwoColImgCardFig, .tswFigLeft, .tswFigRight {
  margin-top: 0.45rem;
  margin-left: 0.45rem;
  margin-right: 0.45rem;
}

figcaption {
  display: table-caption;
  caption-side: bottom;
  text-align: center;
  margin-bottom: 0.5rem;
}

.tswTwoColImgCard figcaption, .tswFlipFlopRowContainer figcaption, .tswFloatingImgContainer figcaption {
  margin-bottom: 0;
}

.tswCaption {
  font-size: 0.65rem;
}

.tswThumbnailTwo {
  width: 310px;
}

.tswThumbnailPortrait {
  width: 205px;
}

img {
   border: 0.5px solid #000000;
}

.tswNoBorder {
   border: none;
}

      /* HOVER CAPTION IF ONLY 3 IMAGES ACROSS*/

.tswThreeColTextImgContainer > .tswImgGridCaptionContainer > .tswCaption {
  font-size: 0.75rem;
}

    /* EXPANDED IMG CAPTION */

.tswImgGridButtonSelected > .tswExpandedImgContainer > figcaption > .tswCaption {
  font-size: 0.85rem;
}


  /*IMAGES IN TEXT */

.tswImgInTextContainer {
  position: relative;
}



/* 3. Sections */

.body-container-wrapper {
    margin: 0 auto;
    max-width: 90%;
  }

.tswSitePageSidebarContainer {
  display: none;
}

.tswSectionContents {
  margin-left: 1rem;
}

.tswBorderedSection {
  border: 1.5px solid #F05C5C;
  border-radius: 25px;
  margin: 1.2rem 0;
  padding: 1rem;
}

.tswRidgeBorder {
  border: 5px ridge white;
  background-color: #e6e7e8;
  margin: 0;
  padding: 0.5rem;
}

.tswBorderedSectionSidebar {
  border: 2px dotted #000000;
  border-radius: 25px;
  background-color: #e6e7e8;
  margin: 1.2rem 0;
  padding: 0.5rem;
}

.tswNoHeadingSection {
  border-top: 2px solid;
  border-top-color: #F05C5C;
  margin-top: 1rem;
}

.tswFlexSectionCentered {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: center;
  align-items: center;
}

.tswFlexSectionSpaced {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-evenly;
  align-items: center;
}  

.tswFlexSectionPushed {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: stretch;
}  

    
@media (min-width:767px){
  .body-container-wrapper {
      max-width: 85%;
  }
  
  .tswSitePageGridContainer {
      display: grid;
      grid-template-columns: 1fr 30%;
  }
  
  .tswSitePageSidebarContainer {
      display: flex;
      align-items: center;
      text-align: center;
   }
   
  .tswSitePageSidebar {
      padding-left: 5rem;
   }
}



/* 4a. Three Column Text */

.tswThreeColImg {
  height: auto; 
  max-width: 100%; 
  margin: 0;
}

.tswFlexSectionText {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: stretch;
  padding: 1rem;
}

.tswThreeColText {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}

@media (min-width:767px){

  .tswFlexSectionText {
      flex-wrap: nowrap;
      padding-left: 0.5rem;
      padding-right: 0.5rem;
  }
  
  .tswThreeColText {
      flex-basis: 33.33%;
      padding: 0 0.5rem;
  }
  
  .tswThreeColText:first-child {
      border-right: 1px solid #F05C5C;
  }
  
  .tswThreeColText:last-child {
      border-left: 1px solid #F05C5C;
  }
  

  
/* 4b. Flip Flop Rows */
  
  .tswRowLayout {
      flex-wrap: nowrap;  
      align-items: flex-start;
   }
  
   .tswFigRight {
      flex-shrink: 0;
      margin-left: 0.5rem;
      order: 2;
    }
  
  .tswFigLeft {
      flex-shrink: 0;
      margin-right: 0.5rem;
    }
  
  

/* 5a. Three Column Images (Food Reviews)  */
  
  .tswThreeColImgLayout {
      align-items: flex-start;
      padding: 1rem 0 0.5rem;
  }
  
  .tswThreeColFig {
      flex-basis: 30%;
  }
}



/* 5b. Images in Three Column Text*/

.tswThreeColTextImgContainer {
  position: relative;
  margin-top: 1.25rem;
}

.tswThreeColTextImg {
  vertical-align: middle;
}

@media (min-width:767px){

  .tswThreeColTextContents {
      order: 2
  }

  .tswThreeColTextImgTop {
      order: -1;
      margin-bottom: 0.75rem;
      margin-top: 0;
  }

  .tswThreeColTextImgMiddle {
      order: 1;
      margin-top: 0.75rem; 
  }

  .tswThreeColTextImgBottom {
      order: 3;
      margin-top: 1.25rem;
  }
}



/* 5c. Images in Portrait Image Bar */

.tswPortraitImgContainer {
  position: relative;
  flex-basis: 48%;
}

.tswPortraitImgBar {
  margin-top: 0.75rem;
}

@media (min-width:767px){
  
    .tswSectionGridContainerCenter {
        display: grid;
        grid-template-columns: 17% 1fr;
        align-items: center;
    }  
  
      .tswSectionGridContainerStart {
        display: grid;
        grid-template-columns: 17% 1fr;
        align-items: start;
    }  

    .tswPortraitImgBarContainer {
        padding-right: 1rem;
    }
  
    .tswSectionGridMain {
        order: 2;
    }
  
    .tswPortraitImgBar {
        flex-direction: column;
    }
}



/* 6. Two Column Image Cards */


.tswTwoColImgCard > .tswTwoColImgCardContents {
  margin: 0 0.45rem;
}

.tswFloatingImgContainer {
  position: relative;
  margin: 0.75rem 0 0.75rem 0;
}

h2 ~ .hs_cos_wrapper_type_module > .tswFloatingImgContainer {
  margin-left: 1rem;
}

@media (min-width:767px){
  .tswTwoColImgCardContainer {
      align-items: stretch;
  }
  
  .tswTwoColImgCard {
      flex-basis: 49%;
  }
 
  .tswFloatingImgContainer {
      margin-bottom: 0;
      margin-top: 1.25rem;
  }
  
  .tswSectionContents > .hs_cos_wrapper_type_module:first-child > .tswFloatingImgContainer {
      margin-top: 0.5rem;
  }
  
  .tswFloatingImgContainerRight {
      position: relative;
      float: right;
      margin-left: 0.25rem;
  }

  .tswFloatingImgContainerLeft {
      position: relative;
      float: left;
  }
  
  .tswFloatingImgContainer.tswFloatingImgContainerLeft {
      margin-left: 0;
      margin-right: 1rem;
  }

}



/* 7. Image Grid Settings */

.tswSectionContents .tswImgGridContainer {
  margin-left: 1rem;
}

.tswSectionContents > .hs_cos_wrapper_type_module > .tswImgGridContainer {
  margin-left: 0;
}

.tswNoHeadingSection > .hs_cos_wrapper_type_module > .tswImgGridContainer {
  margin-left: 0;
}

.tswImgGridButton {
  all: unset;
  position: relative;
}

.tswImgGridImage {
  position: relative;
  overflow: hidden;
  max-width: 100%;
  height: auto;
  object-fit: cover;
  vertical-align: top;
}

.tswImgGridCaptionContainer {
  position: absolute;
  top: 0;
  height: 100%;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.tswImgGridCaption {
  visibility: hidden;  
}

.tswExpandedImgCaption {
  display: none;
}

.tswImgGridButton:hover, .tswImgGridButton:focus {
  border: none;
  color: black;
  background-color: transparent;
}

.tswImgGridCaptionContainer:hover  {
  background-color: rgba(230, 231, 232, 0.85);
}

.tswImgGridCaptionContainer:hover .tswImgGridCaption {
  visibility: visible;
}

@media (min-width:767px) {
  .tswImgGridContainer {
      padding: 1.2rem 0;
  }
  
  .tswImagesWithCaptions {
      padding-bottom: 0.5rem;
  }
}



/* 8. Selected Images */

.tswImgGridButtonSelected > .tswExpandedImgContainer {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 999;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background-color: rgba(230, 231, 232);
}

.tswImgGridButtonSelected > .tswExpandedImgContainer > .tswImgGridImage {
  max-height: 90vh;
  max-width: 90vw;
  z-index: 1000;
}

.tswImgGridButtonSelected > .tswExpandedImgContainer > .tswExpandedImgCaption {
  display: block;
}



/* 9. Blog Post Cards */

.tswBlogPostCardsContainer {
  align-items: stretch;
}

h2 + .tswBlogPostMenuContainer {
  padding-top: 1rem;
}

.tswBlogPostCard {
  text-align: center;
}

.tswBorderedSection > .tswBlogPostCard {
  padding-top: 1rem;
}

.tswBorderedSection > .tswBlogPostCard:first-child {
  padding-top: 0;
}

.tswBlogPostCardFeatImg {
  max-width: 100%;
  overflow: hidden;
}

.tswBlogPostCardTitle {
  font-size: 1rem;
}

@media (min-width:767px) {
  .tswBlogPostCard {
      flex-basis: 23.5%;
  }

  .tswBorderedSection > .tswBlogPostCard {
      padding-top: 0;
  }
}



/* 10. Button Icons */

.btnIcon {
  background-repeat: no-repeat;
  width: 30px;
  height: 30px;
  filter: drop-shadow(-2px 2px 2px rgba(0, 0, 0, 0.5));
}

.tswInlineBtn {
  display: inline-block;
  margin-left: 0.25rem;
  width: 20px;
  height: 20px;
}

h3 ~ .btnIcon {
  vertical-align: text-bottom;
}
  


/* 11. Expand & Collapse */

/*.tswHideOnLoad {
  visibility: hidden;
}*/

.tswSectionHeader {
    display: inline-block;
}

.tswExpandContent > h2 ~ .btnIcon {
  background-image: url(https://241954041.fs1.hubspotusercontent-na2.net/hubfs/241954041/raw_assets/public/thesaltyworm/images/tswIcons/tswPlus.svg);
}

.tswExpandContent > h3 ~ .btnIcon {
  background-image: url(https://241954041.fs1.hubspotusercontent-na2.net/hubfs/241954041/raw_assets/public/thesaltyworm/images/tswIcons/tswExpand.svg);
  margin-bottom: 0.15rem;
}

.tswCollapseContent > h2 ~ .btnIcon {
  background-image: url(https://241954041.fs1.hubspotusercontent-na2.net/hubfs/241954041/raw_assets/public/thesaltyworm/images/tswIcons/tswMinus.svg);
}

.tswCollapseContent > h3 ~ .btnIcon {
  background-image: url(https://241954041.fs1.hubspotusercontent-na2.net/hubfs/241954041/raw_assets/public/thesaltyworm/images/tswIcons/tswCollapse.svg);
}

#tswViewOutlineBtn, #tswExpandAllBtn {
  margin-right: 1rem;
  margin-left: 1rem;
}

.tswContentBtnHolder {
  position: sticky;
  top: 0;
  z-index: 10;
  background-color: #F5F5F5;
  padding: 1rem 0;
  border-bottom: 2px solid #CED4DB;
}

.tswExpandContent ~ div.tswSectionContents {
  display: none;
}

.tswCollapsibleBlogContent {
  border-bottom: 2px solid #CED4DB;
  padding-bottom: 1rem;
}



/* 12. Popups */

    /* Container */

.tswPopup {
  position: relative;
  display: inline-block;
  cursor: pointer;
  color: #F05C5C;
  font-weight: 400;
  
}

    /* The actual popup (appears on top) */

.tswPopupText {
  width: 160px;
  background-color: #F05C5C;
  color: #FFFFFF;
  text-align: center;
  border-radius: 6px;
  padding: 8px 8px;
  position: absolute;
  z-index: 1;
  bottom: 125%;
  left: 50%;
  margin-left: -80px;
  font-weight: 300;
}

    /* Show & Hide */

.tswShowPopup > .tswPopupText {
    visibility: visible;
}

.tswHidePopup > .tswPopupText {
    visibility: hidden;
}
.tswHeader_container {
 padding-left: 1rem;
  padding-right: 1rem;
}

/* Button Icons */

.tswOpenMenu {
  background-image: url(https://241954041.fs1.hubspotusercontent-na2.net/hubfs/241954041/raw_assets/public/thesaltyworm/images/tswIcons/tswHamburger.svg);
}

.tswCloseMenu {
  background-image: url(https://241954041.fs1.hubspotusercontent-na2.net/hubfs/241954041/raw_assets/public/thesaltyworm/images/tswIcons/tswCloseBtn.svg);
}

.tswOpenSearch {
  background-image: url(https://241954041.fs1.hubspotusercontent-na2.net/hubfs/241954041/raw_assets/public/thesaltyworm/images/tswIcons/tswSearchIcon.svg);
}


/* Header Container - Mobile View*/

.tswHeader_btnHolder {
  position: sticky;
  top: 0;
  background-color: #e6e7e8;
  z-index: 5;
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 2px solid #CED4DB;
 }
  
.tswOpenMenu {
  display: block;
}


/* Header Container -Desktop View (Note: Screen Limit should match css file for Menu Module} */

@media (min-width:767px){
  
  .tswHeader_menuHolder {
    display: flex;
    justify-content: center;
    border-bottom: 2px solid #CED4DB;
   }
  
  #tswControlMobileMenu {
    display: none
   }
  
  .tswHeader_btnHolder {
    order: 2;
    border: none;
  }
  
}


/* Logo */

.tswLogoHolderRegular {
  display: flex;
  justify-content: center;
}

.tswSitePageLogo {
  width: 100%;
  margin-bottom: 0.75rem;
  margin-top: 0.75rem;
}

@media (min-width:767px){
  
  .tswSitePageLogo {
    width: 60%;
    margin-top: 0.5rem;
    margin-bottom: 0.5rem;
  }
  
}


/* Search Function */

    /* Search Icon */

#tswControlSearchBar {
  margin-left: 0.85rem;
  margin-top: 0.4rem;
  margin-bottom: 0.2rem;
  z-index: 1000;
}

.tswHideSearchBtn {
  visibility: hidden;
}

    /* Overlay */

#pageOverlay {
  position: fixed; 
  top: 0; 
  left: 0; 
  width: 100%;
  height: 100%;
  background-color: rgba(0,0,0,0.5); 
  z-index: 999
}

.overlayOff{
  display:none;
}

.tswNoSticky {
  position: relative;
  z-index: auto;
}

    /* Search Bar */

.tswSearchFieldClosed {
  height: 0;
  overflow: hidden;
}

.tswSearchFieldOpen {
  margin-top: 0.4rem;
  height: 40px;
}

.tswSearchField {
  display: flex;
  justify-content: center;
  position: relative;
  z-index: 1000;
}

.tswSearchBar {
  width: 35%;
}

#tswSearchResultsHeading {
  text=align: center;
}
    /* Hubspot Settings */

.hs-search-field__form {
  display: flex;
  flex-wrap: wrap;
}

.hs-search-field__input {
  box-sizing: border-box;
  width: 100%;
  flex: 1;
  border-bottom: none;
  border-radius: 6px 6px 0 0;
  max-width: 100%;
  margin-right: 3px;
}

.hs-search-field__suggestions {
  background-color: #FFF;
  border: 2px solid #D1D6DC;
  border-radius: 0 0 6px 6px;
  border-top-width: 1px;
  position: absolute;
  width: 100%;
  z-index: 1000;
}

.hs-search-field__suggestions li {
  border-top: 1px solid #D1D6DC;
  font-size: 0.875rem;
}

.hs-search-field__suggestions li a {
  color: #494A52;
  padding: 0.35rem 0.7rem;
  text-decoration: none;
  transition: background-color 0.3s;
}

.hs-search-field__suggestions #results-for {
  display: none;
}
/* Menu and simple menu */

.hs-menu-wrapper ul {
  display: flex;
  flex-wrap: wrap;
  list-style: none;
  margin: 0;
  padding-left: 0;
}

/* Horizontal menu */

.hs-menu-wrapper.hs-menu-flow-horizontal .hs-menu-children-wrapper {
  flex-direction: column;
}

@media (max-width: 767px) {
  .hs-menu-wrapper.hs-menu-flow-horizontal ul {
    flex-direction: column;
  }
}

/* Vertical menu */

.hs-menu-wrapper.hs-menu-flow-vertical ul {
  flex-direction: column;
}

/* Flyouts */

.hs-menu-wrapper.hs-menu-flow-vertical.flyouts ul {
  display: inline-flex;
}

@media (max-width: 767px) {
  .hs-menu-wrapper.hs-menu-flow-vertical ul {
    display: flex;
  }
}

.hs-menu-wrapper.flyouts .hs-item-has-children {
  position: relative;
}

.hs-menu-wrapper.flyouts .hs-menu-children-wrapper {
  left: -9999px;
  opacity: 0;
  position: absolute;
}

.hs-menu-wrapper.flyouts .hs-menu-children-wrapper a {
  display: block;
  white-space: nowrap;
}

.hs-menu-wrapper.hs-menu-flow-horizontal.flyouts .hs-item-has-children:hover > .hs-menu-children-wrapper {
  left: 0;
  opacity: 1;
  top: 100%;
}

.hs-menu-wrapper.hs-menu-flow-vertical.flyouts .hs-item-has-children:hover > .hs-menu-children-wrapper {
  left: 100%;
  opacity: 1;
  top: 0;
}

@media (max-width: 767px) {
  .hs-menu-wrapper.flyouts .hs-menu-children-wrapper,
  .hs-menu-wrapper.hs-menu-flow-horizontal.flyouts .hs-item-has-children:hover > .hs-menu-children-wrapper,
  .hs-menu-wrapper.hs-menu-flow-vertical.flyouts .hs-item-has-children:hover > .hs-menu-children-wrapper {
    left: 0;
    opacity: 1;
    position: relative;
    top: auto;
  }
}

/* CTA, logo, and rich text images */

.hs_cos_wrapper_type_cta img,
.hs_cos_wrapper_type_logo img,
.hs_cos_wrapper_type_rich_text img {
  height: auto;
  max-width: 100%;
}

/* Utilities
Helper classes with ability to override anything that comes before it
*/

/* For content that needs to be visually hidden but stay visible for screenreaders */

.show-for-sr {
  border: 0 !important;
  clip: rect(0, 0, 0, 0) !important;
  height: 1px !important;
  overflow: hidden !important;
  padding: 0 !important;
  position: absolute !important;
  white-space: nowrap !important;
  width: 1px !important;
}

@media (max-width: 767px) {
  .show-for-sr--mobile {
    border: 0 !important;
    clip: rect(0, 0, 0, 0) !important;
    height: 1px !important;
    overflow: hidden !important;
    padding: 0 !important;
    position: absolute !important;
    white-space: nowrap !important;
    width: 1px !important;
  }
}