.ttp-trip-save-place,
.ttp-trip-save-page,
.ttp-trip-unsave-place,
.ttp-trip-primary,
.ttp-trip-secondary,
.ttp-trip-danger,
.ttp-trip-provider,
.ttp-trip-register,
.ttp-account-panel a,
.ttp-account-panel button {
  display: inline-flex;
  min-height: 38px;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 9px 13px;
  border: 1px solid rgba(31, 41, 55, .16);
  border-radius: 999px;
  background: rgba(255, 253, 248, .86);
  color: #172033;
  font: inherit;
  font-size: 12px;
  font-weight: 950;
  letter-spacing: .055em;
  line-height: 1;
  text-decoration: none;
  text-transform: uppercase;
  box-shadow: 0 12px 28px rgba(15, 23, 42, .08);
  cursor: pointer;
}

.ttp-trip-save-place {
  border-color: rgba(111, 59, 44, .22);
  color: #6f3b2c;
}

.ttp-trip-unsave-place {
  min-height: 34px;
  margin-left: 8px;
  padding: 8px 11px;
  border-color: rgba(111, 59, 44, .20);
  background: rgba(255, 253, 248, .72);
  color: #6f3b2c;
  box-shadow: none;
}

.ttp-trip-save-page-panel {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  width: min(100%, 980px);
  margin: 18px auto;
  padding: 14px 16px;
  border: 1px solid rgba(31, 41, 55, .13);
  border-top: 3px solid #6f3b2c;
  border-radius: 18px;
  background:
    linear-gradient(135deg, rgba(49, 95, 93, .08), transparent 58%),
    rgba(255, 253, 248, .88);
  box-shadow: 0 18px 42px rgba(15, 23, 42, .08);
}

.ttp-trip-save-page-panel div {
  display: grid;
  gap: 3px;
}

.ttp-trip-save-page-panel strong {
  color: #172033;
  font-size: 15px;
  font-weight: 950;
}

.ttp-trip-save-page-panel span {
  color: #536071;
  font-size: 12px;
  font-weight: 800;
}

.ttp-trip-save-page {
  flex: 0 0 auto;
  background: #172033;
  color: #fff;
}

.ttp-trip-save-place::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: currentColor;
  opacity: .72;
}

.ttp-trip-save-place:hover,
.ttp-trip-save-place:focus,
.ttp-trip-unsave-place:hover,
.ttp-trip-unsave-place:focus,
.ttp-trip-primary:hover,
.ttp-trip-primary:focus,
.ttp-trip-secondary:hover,
.ttp-trip-secondary:focus,
.ttp-trip-danger:hover,
.ttp-trip-danger:focus,
.ttp-trip-provider:hover,
.ttp-trip-provider:focus,
.ttp-trip-register:hover,
.ttp-trip-register:focus {
  transform: translateY(-1px);
}

.ttp-trip-save-place.is-saved,
.ttp-trip-save-place:disabled,
.ttp-trip-save-page.is-saved,
.ttp-trip-save-page:disabled {
  border-color: rgba(49, 95, 93, .22);
  color: #315f5d;
  cursor: default;
  opacity: 1;
}

.ttp-trip-save-page.is-saved,
.ttp-trip-save-page:disabled {
  background: rgba(255, 253, 248, .86);
}

.ttp-trip-secondary.is-disabled,
.ttp-trip-secondary:disabled {
  opacity: .52;
  pointer-events: none;
}

.ttp-trip-auth-open {
  overflow: hidden;
}

.ttp-trip-map-picker-open {
  overflow: hidden;
}

.ttp-trip-auth-modal[hidden] {
  display: none;
}

.ttp-trip-map-picker[hidden] {
  display: none;
}

.ttp-trip-auth-modal,
.ttp-trip-map-picker {
  position: fixed;
  inset: 0;
  z-index: 999999;
  display: grid;
  place-items: center;
  padding: 22px;
}

.ttp-trip-auth-backdrop,
.ttp-trip-map-picker__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, .66);
  backdrop-filter: blur(8px);
}

.ttp-trip-auth-dialog,
.ttp-trip-map-picker__dialog {
  position: relative;
  width: min(100%, 560px);
  overflow: hidden;
  padding: clamp(24px, 4vw, 38px);
  border: 1px solid rgba(31, 41, 55, .16);
  border-top: 4px solid #6f3b2c;
  border-radius: 20px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .88), rgba(255, 253, 248, .58)),
    repeating-linear-gradient(0deg, transparent 0 35px, rgba(31, 41, 55, .045) 35px 36px),
    #fffaf3;
  box-shadow: 0 34px 80px rgba(0, 0, 0, .30);
}

.ttp-trip-auth-close,
.ttp-trip-map-picker__close {
  position: absolute;
  top: 14px;
  right: 14px;
  display: grid;
  width: 42px;
  height: 42px;
  place-items: center;
  border: 1px solid rgba(31, 41, 55, .13);
  border-radius: 999px;
  background: rgba(255, 255, 255, .72);
  color: #172033;
  cursor: pointer;
  font-size: 28px;
  line-height: 1;
}

.ttp-trip-map-picker__maps {
  display: grid;
  gap: 10px;
  margin: 18px 0;
}

.ttp-trip-map-picker__maps button {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  width: 100%;
  padding: 13px 14px;
  border: 1px solid rgba(31, 41, 55, .13);
  border-radius: 14px;
  background: rgba(255, 253, 248, .74);
  color: #172033;
  cursor: pointer;
  font: inherit;
  text-align: left;
}

.ttp-trip-map-picker__maps button:hover,
.ttp-trip-map-picker__maps button:focus {
  border-color: rgba(49, 95, 93, .36);
  outline: 0;
  box-shadow: 0 14px 30px rgba(15, 23, 42, .10);
}

.ttp-trip-map-picker__maps strong {
  font-size: 15px;
  font-weight: 950;
}

.ttp-trip-map-picker__maps span {
  color: #536071;
  font-size: 12px;
  font-weight: 850;
}

.ttp-trip-map-picker__new {
  display: grid;
  gap: 10px;
  padding-top: 14px;
  border-top: 1px solid rgba(31, 41, 55, .10);
}

.ttp-trip-map-picker__new label {
  display: grid;
  gap: 7px;
  color: #6f3b2c;
  font-size: 11px;
  font-weight: 950;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.ttp-trip-map-picker__new input {
  min-height: 44px;
  padding: 10px 12px;
  border: 1px solid rgba(31, 41, 55, .14);
  border-radius: 12px;
  background: rgba(255, 255, 255, .78);
  color: #172033;
  font: inherit;
  font-size: 14px;
  letter-spacing: 0;
  text-transform: none;
}

.ttp-trip-kicker {
  display: inline-flex;
  min-height: 30px;
  align-items: center;
  padding: 7px 11px;
  border: 1px solid rgba(31, 41, 55, .16);
  border-radius: 999px;
  background: rgba(255, 253, 248, .72);
  color: #354052;
  font-size: 11px;
  font-weight: 950;
  letter-spacing: .085em;
  line-height: 1;
  text-transform: uppercase;
}

.ttp-trip-auth-dialog h2,
.ttp-trip-planner h2 {
  max-width: 10ch;
  margin: 12px 0;
  color: #172033;
  font-size: clamp(34px, 6vw, 58px);
  font-weight: 950;
  letter-spacing: -.01em;
  line-height: .98;
}

.ttp-trip-auth-dialog p,
.ttp-trip-planner p {
  color: #536071;
  font-size: 16px;
  line-height: 1.58;
}

.ttp-trip-auth-actions {
  display: grid;
  gap: 10px;
  margin-top: 22px;
}

.ttp-trip-auth-choice-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.ttp-trip-auth-choice {
  display: inline-flex;
  min-height: 46px;
  align-items: center;
  justify-content: center;
  padding: 10px 13px;
  border: 1px solid rgba(31, 41, 55, .16);
  border-radius: 8px;
  background: rgba(255, 253, 248, .86);
  color: #172033;
  cursor: pointer;
  font: inherit;
  font-size: 12px;
  font-weight: 950;
  letter-spacing: .055em;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
}

.ttp-trip-auth-choice:hover,
.ttp-trip-auth-choice:focus,
.ttp-trip-auth-choice.is-active {
  border-color: rgba(49, 95, 93, .35);
  background: rgba(49, 95, 93, .08);
  outline: 0;
}

.ttp-trip-auth-form {
  display: grid;
  gap: 12px;
  padding: 14px;
  border: 1px solid rgba(31, 41, 55, .12);
  border-radius: 14px;
  background: rgba(255, 253, 248, .78);
}

.ttp-trip-auth-form[hidden] {
  display: none;
}

.ttp-trip-auth-form h3 {
  margin: 0;
  color: #172033;
  font-size: 18px;
  line-height: 1.15;
}

.ttp-trip-auth-form label {
  display: grid;
  gap: 6px;
}

.ttp-trip-auth-form label span {
  color: #6f3b2c;
  font-size: 11px;
  font-weight: 950;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.ttp-trip-auth-form input {
  width: 100%;
  min-height: 42px;
  padding: 10px 12px;
  border: 1px solid rgba(31, 41, 55, .14);
  border-radius: 10px;
  background: rgba(255, 255, 255, .88);
  color: #172033;
  font: inherit;
}

.ttp-trip-auth-form input:focus {
  border-color: rgba(49, 95, 93, .42);
  outline: 0;
  box-shadow: 0 0 0 3px rgba(49, 95, 93, .10);
}

.ttp-trip-auth-hp {
  position: absolute;
  left: -9999px;
}

.ttp-trip-auth-status {
  min-height: 18px;
  margin: 0;
  color: #315f5d;
  font-size: 13px;
  font-weight: 800;
}

.ttp-trip-auth-status.is-error {
  color: #9f1239;
}

.ttp-trip-provider,
.ttp-trip-primary {
  min-height: 46px;
  border-radius: 8px;
}

.ttp-trip-provider.is-google {
  border-color: rgba(111, 59, 44, .24);
}

.ttp-trip-provider.is-facebook {
  border-color: rgba(49, 95, 93, .24);
}

.ttp-trip-provider.is-x {
  border-color: rgba(17, 24, 39, .18);
  background: #111827;
  color: #fff;
}

.ttp-trip-provider.is-email,
.ttp-trip-primary {
  background: #172033;
  color: #fff;
}

.ttp-trip-provider.is-disabled {
  color: #7a6f60;
  cursor: default;
  opacity: .72;
}

.ttp-trip-provider.is-x.is-disabled {
  border-color: rgba(31, 41, 55, .14);
  background: rgba(255, 253, 248, .76);
  color: #7a6f60;
}

.ttp-trip-register {
  justify-self: center;
  box-shadow: none;
}

.ttp-trip-planner,
.ttp-account-panel {
  width: min(100%, 1180px);
  margin: clamp(24px, 5vw, 56px) auto;
}

.ttp-trip-planner {
  position: relative;
  z-index: 80;
  padding: clamp(22px, 4vw, 38px);
  border: 1px solid rgba(31, 41, 55, .14);
  border-top: 3px solid #6f3b2c;
  border-radius: 12px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, .94), rgba(250, 246, 237, .76)),
    repeating-linear-gradient(0deg, transparent 0 37px, rgba(31, 41, 55, .025) 37px 38px),
    #fffaf3;
  box-shadow: 0 24px 60px rgba(15, 23, 42, .11);
}

body.page-id-14759 .ttp-editorial-entry-hero--page {
  display: none;
}

.ttp-trip-planner-empty.is-phone-landing {
  display: grid;
  width: min(100%, 1180px);
  grid-template-columns: minmax(0, .78fr) minmax(290px, .72fr);
  align-items: center;
  gap: clamp(22px, 4vw, 52px);
  overflow: hidden;
  padding: clamp(24px, 4vw, 46px);
}

.ttp-trip-empty-copy {
  display: grid;
  justify-items: start;
  gap: 18px;
  min-width: 0;
}

.ttp-trip-empty-copy h2 {
  max-width: 10.5ch;
  margin: 0;
  color: #172033;
  font-size: clamp(38px, 5.4vw, 76px);
  font-weight: 950;
  letter-spacing: 0;
  line-height: .92;
}

.ttp-trip-empty-copy p:not(.ttp-trip-kicker) {
  max-width: 34rem;
  margin: 0;
  color: #536071;
  font-size: clamp(15px, 1.4vw, 18px);
  font-weight: 760;
  line-height: 1.55;
}

.ttp-trip-planner-head {
  position: relative;
  display: block;
}

.ttp-trip-hero-banner {
  position: relative;
  display: grid;
  min-height: clamp(104px, 11vw, 136px);
  overflow: hidden;
  grid-template-columns: minmax(0, .82fr) minmax(260px, .62fr);
  align-items: stretch;
  border: 1px solid rgba(31, 41, 55, .18);
  border-top: 4px solid transparent;
  border-image: linear-gradient(90deg, #d99d2b, #b24b5d, #315f5d) 1;
  border-radius: 11px;
  background:
    linear-gradient(115deg, rgba(255, 253, 248, .98) 0 54%, rgba(237, 230, 216, .88) 54% 100%),
    repeating-linear-gradient(0deg, transparent 0 35px, rgba(49, 95, 93, .035) 35px 36px),
    #fffaf3;
  box-shadow: 0 20px 48px rgba(15, 23, 42, .10);
}

.ttp-trip-hero-banner::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(49, 95, 93, .055) 1px, transparent 1px),
    linear-gradient(0deg, rgba(49, 95, 93, .045) 1px, transparent 1px);
  background-size: 42px 42px;
  opacity: .72;
  pointer-events: none;
}

.ttp-trip-hero-banner::after {
  content: "";
  position: absolute;
  right: 8%;
  bottom: -72px;
  width: 190px;
  height: 190px;
  border: 1px solid rgba(49, 95, 93, .17);
  border-radius: 50%;
  background:
    radial-gradient(circle, rgba(255, 253, 248, .96) 0 2px, transparent 3px),
    repeating-conic-gradient(from -22deg, rgba(49, 95, 93, .18) 0 2deg, transparent 2deg 18deg);
  opacity: .74;
  pointer-events: none;
}

.ttp-trip-hero-copy {
  position: relative;
  z-index: 1;
  display: grid;
  align-content: center;
  max-width: 620px;
  padding: clamp(16px, 2.6vw, 28px);
}

.ttp-trip-hero-copy span {
  color: #6f3b2c;
  font-size: 11px;
  font-weight: 950;
  letter-spacing: .18em;
  text-transform: uppercase;
}

.ttp-trip-hero-copy h2 {
  max-width: none;
  margin: 5px 0 7px;
  color: #172033;
  font-size: clamp(30px, 4vw, 52px);
  font-weight: 950;
  letter-spacing: 0;
  line-height: .94;
}

.ttp-trip-hero-copy p {
  max-width: 38rem;
  margin: 0;
  color: #536071;
  font-size: clamp(13px, 1.25vw, 15px);
  font-weight: 750;
  line-height: 1.44;
}

.ttp-trip-hero-art {
  position: relative;
  min-height: 100%;
  overflow: hidden;
  background:
    linear-gradient(135deg, rgba(255, 253, 248, .68), rgba(255, 255, 255, .18)),
    radial-gradient(circle at 74% 30%, rgba(49, 95, 93, .16), transparent 26%),
    radial-gradient(circle at 38% 70%, rgba(217, 157, 43, .18), transparent 26%);
}

.ttp-trip-hero-art::before,
.ttp-trip-hero-art::after {
  content: "";
  position: absolute;
  inset: 14px 34px;
  border: 1px solid rgba(49, 95, 93, .15);
  border-radius: 16px;
  transform: rotate(-3deg);
}

.ttp-trip-hero-art::after {
  inset: 28px 62px 22px 18px;
  border-color: rgba(111, 59, 44, .16);
  background:
    linear-gradient(90deg, transparent 0 34%, rgba(111, 59, 44, .13) 34% 35%, transparent 35%),
    linear-gradient(0deg, transparent 0 48%, rgba(49, 95, 93, .11) 48% 49%, transparent 49%);
  transform: rotate(5deg);
}

.ttp-trip-hero-route {
  position: absolute;
  right: 15%;
  bottom: 18%;
  width: 70%;
  height: 42%;
  border-bottom: 4px dashed rgba(49, 95, 93, .72);
  border-left: 4px dashed rgba(49, 95, 93, .72);
  border-radius: 0 0 0 70px;
  transform: rotate(-10deg);
}

.ttp-trip-hero-route::after {
  content: "";
  position: absolute;
  right: -10px;
  bottom: -10px;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: #6f3b2c;
  box-shadow: 0 0 0 7px rgba(111, 59, 44, .14);
}

.ttp-trip-hero-pin {
  position: absolute;
  z-index: 2;
  width: 13px;
  height: 13px;
  border: 3px solid #fffaf3;
  border-radius: 999px;
  background: #315f5d;
  box-shadow: 0 0 0 1px rgba(31, 41, 55, .16), 0 14px 28px rgba(15, 23, 42, .18);
}

.ttp-trip-hero-pin.is-one {
  top: 29%;
  left: 24%;
}

.ttp-trip-hero-pin.is-two {
  right: 28%;
  top: 44%;
  background: #d99d2b;
}

.ttp-trip-hero-pin.is-three {
  right: 18%;
  bottom: 24%;
  background: #6f3b2c;
}

.ttp-trip-hero-compass {
  position: absolute;
  right: 11%;
  top: 17%;
  z-index: 1;
  width: 58px;
  height: 58px;
  border: 1px solid rgba(31, 41, 55, .13);
  border-radius: 50%;
  background:
    linear-gradient(135deg, transparent 45%, rgba(111, 59, 44, .25) 45% 53%, transparent 53%),
    rgba(255, 250, 243, .68);
  box-shadow: inset 0 0 0 12px rgba(255, 255, 255, .42), 0 16px 32px rgba(15, 23, 42, .08);
}

.ttp-trip-user-menu {
  position: absolute;
  top: 14px;
  right: 14px;
  z-index: 9999;
  display: flex;
  align-items: center;
  gap: 8px;
}

.ttp-trip-user-chip {
  appearance: none;
  display: inline-flex;
  min-height: 36px;
  align-items: center;
  gap: 8px;
  padding: 5px 8px 5px 5px;
  border: 1px solid rgba(31, 41, 55, .14);
  border-radius: 999px;
  background: rgba(255, 250, 243, .9);
  color: #172033;
  cursor: pointer;
  font: inherit;
  text-align: left;
  box-shadow: 0 10px 20px rgba(15, 23, 42, .10);
}

.ttp-trip-user-chip::after {
  content: "";
  width: 6px;
  height: 6px;
  flex: 0 0 auto;
  margin-left: 1px;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  opacity: .58;
  transform: translateY(-2px) rotate(45deg);
}

.ttp-trip-user-chip:hover,
.ttp-trip-user-chip:focus {
  background: #fffaf3;
  outline: 0;
  box-shadow: 0 0 0 3px rgba(49, 95, 93, .12), 0 10px 20px rgba(15, 23, 42, .10);
}

.ttp-trip-user-chip img,
.ttp-trip-user-chip b {
  display: grid;
  width: 26px;
  height: 26px;
  flex: 0 0 auto;
  place-items: center;
  overflow: hidden;
  border-radius: 999px;
  background: #172033;
  color: #fff;
  font-size: 12px;
  font-weight: 950;
  line-height: 1;
}

.ttp-trip-user-chip img {
  object-fit: cover;
}

.ttp-trip-user-chip span {
  display: grid;
  gap: 1px;
}

.ttp-trip-user-chip strong {
  max-width: 150px;
  overflow: hidden;
  color: #172033;
  font-size: 11px;
  font-weight: 950;
  line-height: 1.05;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ttp-trip-user-chip em {
  color: #6f3b2c;
  font-size: 9px;
  font-style: normal;
  font-weight: 950;
  letter-spacing: .08em;
  line-height: 1;
  text-transform: uppercase;
}

.ttp-trip-user-dropdown {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  z-index: 10000;
  display: grid;
  width: min(260px, calc(100vw - 36px));
  gap: 6px;
  padding: 8px;
  border: 1px solid rgba(31, 41, 55, .14);
  border-radius: 10px;
  background: rgba(255, 250, 243, .98);
  color: #172033;
  box-shadow: 0 18px 36px rgba(15, 23, 42, .16);
}

.ttp-trip-user-dropdown[hidden] {
  display: none;
}

.ttp-trip-menu-action {
  appearance: none;
  display: flex;
  width: 100%;
  min-height: 36px;
  align-items: center;
  justify-content: flex-start;
  padding: 9px 10px;
  border: 1px solid transparent;
  border-radius: 7px;
  background: transparent;
  color: #172033;
  cursor: pointer;
  font: inherit;
  font-size: 10px;
  font-weight: 950;
  letter-spacing: .08em;
  line-height: 1.2;
  text-decoration: none;
  text-transform: uppercase;
  box-shadow: none;
  text-align: left;
}

.ttp-trip-menu-action:hover,
.ttp-trip-menu-action:focus {
  border-color: rgba(49, 95, 93, .18);
  background: rgba(49, 95, 93, .08);
  outline: 0;
}

.ttp-trip-menu-action[disabled],
.ttp-trip-menu-action[aria-disabled="true"] {
  cursor: wait;
  opacity: .68;
}

.ttp-trip-menu-status {
  min-height: 16px;
  margin: 2px 2px 0;
  color: #315f5d;
  font-size: 11px;
  font-weight: 800;
  line-height: 1.35;
}

.ttp-trip-planner .ttp-trip-primary,
.ttp-trip-planner .ttp-trip-secondary,
.ttp-trip-planner .ttp-trip-danger {
  border-radius: 7px;
  box-shadow: 0 10px 22px rgba(15, 23, 42, .07);
}

.ttp-trip-danger {
  border-color: rgba(111, 59, 44, .22);
  background: rgba(255, 253, 248, .84);
  color: #6f3b2c;
}

.ttp-trip-compact-list {
  margin-top: 18px;
}

.ttp-trip-saved-mini {
  display: grid;
  gap: 10px;
  max-width: 560px;
  padding: 12px;
  border: 1px solid rgba(31, 41, 55, .12);
  border-radius: 10px;
  background:
    linear-gradient(135deg, rgba(49, 95, 93, .05), transparent 58%),
    rgba(255, 253, 248, .72);
  box-shadow: 0 14px 30px rgba(15, 23, 42, .07);
}

.ttp-trip-saved-mini header,
.ttp-trip-saved-mini li {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto auto auto;
  gap: 8px;
  align-items: center;
}

.ttp-trip-saved-mini header {
  grid-template-columns: minmax(0, 1fr) auto;
}

.ttp-trip-saved-mini header strong,
.ttp-trip-saved-mini div strong {
  display: block;
  color: #172033;
  font-size: 14px;
  font-weight: 950;
}

.ttp-trip-saved-mini header span,
.ttp-trip-saved-mini div span {
  display: block;
  margin-top: 2px;
  color: #536071;
  font-size: 11px;
  font-weight: 850;
}

.ttp-trip-saved-mini header b {
  display: grid;
  width: 32px;
  height: 32px;
  place-items: center;
  border-radius: 999px;
  background: #172033;
  color: #fff;
  font-size: 13px;
  font-weight: 950;
}

.ttp-trip-saved-mini ol {
  display: grid;
  gap: 7px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.ttp-trip-saved-mini li {
  padding: 8px;
  border: 1px solid rgba(31, 41, 55, .10);
  border-radius: 7px;
  background: rgba(255, 255, 255, .62);
}

.ttp-trip-saved-mini li.is-muted {
  opacity: .62;
}

.ttp-trip-saved-mini li > b {
  display: grid;
  width: 27px;
  height: 27px;
  place-items: center;
  border-radius: 999px;
  background: #315f5d;
  color: #fff;
  font-size: 11px;
  font-weight: 950;
}

.ttp-trip-saved-mini li strong {
  display: block;
  overflow: hidden;
  color: #172033;
  font-size: 13px;
  font-weight: 950;
  line-height: 1.15;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ttp-trip-saved-mini li small {
  display: block;
  overflow: hidden;
  margin-top: 2px;
  color: #536071;
  font-size: 11px;
  font-weight: 800;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ttp-trip-saved-mini label {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  color: #354052;
  font-size: 10px;
  font-weight: 950;
  letter-spacing: .05em;
  text-transform: uppercase;
}

.ttp-trip-saved-mini input {
  width: 15px;
  height: 15px;
  accent-color: #315f5d;
}

.ttp-trip-saved-mini a,
.ttp-trip-saved-mini button {
  display: inline-flex;
  min-height: 28px;
  align-items: center;
  padding: 6px 8px;
  border: 1px solid rgba(31, 41, 55, .13);
  border-radius: 5px;
  background: rgba(255, 253, 248, .78);
  color: #172033;
  cursor: pointer;
  font: inherit;
  font-size: 10px;
  font-weight: 950;
  letter-spacing: .04em;
  line-height: 1;
  text-decoration: none;
  text-transform: uppercase;
}

.ttp-trip-saved-mini button {
  color: #6f3b2c;
}

.ttp-trip-saved-mini-more {
  margin: -2px 0 0;
  color: #536071;
  font-size: 11px;
  font-weight: 850;
}

.ttp-trip-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 0;
  margin-top: 22px;
  border-top: 1px solid rgba(31, 41, 55, .12);
  border-bottom: 1px solid rgba(31, 41, 55, .12);
  background: rgba(255, 253, 248, .56);
}

.ttp-trip-tabs button {
  position: relative;
  min-height: 46px;
  padding: 13px 18px;
  border: 0;
  border-right: 1px solid rgba(31, 41, 55, .10);
  background: transparent;
  color: #596476;
  cursor: pointer;
  font: inherit;
  font-size: 12px;
  font-weight: 950;
  letter-spacing: .095em;
  line-height: 1;
  text-transform: uppercase;
}

.ttp-trip-tabs button::after {
  content: "";
  position: absolute;
  right: 16px;
  bottom: -1px;
  left: 16px;
  height: 3px;
  background: transparent;
}

.ttp-trip-tabs button.is-active {
  background: rgba(255, 255, 255, .66);
  color: #172033;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .78);
}

.ttp-trip-tabs button.is-active::after {
  background: linear-gradient(90deg, #6f3b2c, #315f5d);
}

.ttp-trip-tab-panel:not(.is-active) {
  display: none;
}

.ttp-trip-overview-panel {
  display: block;
}

.ttp-trip-planner.has-active-section .ttp-trip-overview-panel {
  display: none;
}

.ttp-trip-dashboard {
  display: grid;
  grid-template-columns: minmax(260px, .52fr) minmax(0, 1fr);
  gap: 22px;
  margin-top: 20px;
  padding: clamp(20px, 3vw, 30px);
  border: 1px solid rgba(31, 41, 55, .12);
  border-radius: 10px;
  background:
    linear-gradient(135deg, rgba(49, 95, 93, .06), transparent 52%),
    linear-gradient(180deg, rgba(255, 255, 255, .74), rgba(255, 253, 248, .54));
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .72);
}

.ttp-trip-dashboard-side {
  display: grid;
  gap: 12px;
  align-content: center;
}

.ttp-trip-dashboard-stats {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.ttp-trip-dashboard-stats span {
  display: grid;
  min-height: 86px;
  align-content: center;
  gap: 4px;
  padding: 13px;
  border: 1px solid rgba(31, 41, 55, .12);
  border-radius: 8px;
  background: rgba(255, 253, 248, .82);
  color: #536071;
  font-size: 11px;
  font-weight: 950;
  letter-spacing: .08em;
  line-height: 1.15;
  text-transform: uppercase;
  box-shadow: 0 12px 28px rgba(15, 23, 42, .05);
}

.ttp-trip-dashboard-stats strong {
  display: block;
  color: #172033;
  font-size: 30px;
  font-weight: 950;
  letter-spacing: 0;
  line-height: 1;
  text-transform: none;
}

.ttp-trip-next-action {
  display: grid;
  gap: 7px;
  padding: 16px;
  border: 1px solid rgba(49, 95, 93, .18);
  border-left: 4px solid #315f5d;
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(49, 95, 93, .09), transparent 64%),
    rgba(255, 253, 248, .82);
  box-shadow: 0 14px 30px rgba(15, 23, 42, .07);
}

.ttp-trip-next-action span {
  color: #6f3b2c;
  font-size: 10px;
  font-weight: 950;
  letter-spacing: .16em;
  text-transform: uppercase;
}

.ttp-trip-next-action strong {
  color: #172033;
  font-size: 20px;
  font-weight: 950;
  line-height: 1.12;
}

.ttp-trip-next-action p {
  margin: 0;
  color: #536071;
  font-size: 13px;
  font-weight: 780;
  line-height: 1.45;
}

.ttp-trip-welcome-copy {
  display: grid;
  align-content: center;
  gap: 12px;
}

.ttp-trip-welcome-copy span {
  color: #6f3b2c;
  font-size: 11px;
  font-weight: 950;
  letter-spacing: .18em;
  text-transform: uppercase;
}

.ttp-trip-welcome-copy h3 {
  max-width: 9ch;
  margin: 0;
  color: #172033;
  font-size: clamp(34px, 4.8vw, 64px);
  font-weight: 950;
  letter-spacing: 0;
  line-height: .96;
}

.ttp-trip-welcome-copy p {
  max-width: 34rem;
  margin: 0;
  color: #536071;
  font-size: 17px;
  font-weight: 720;
  line-height: 1.52;
}

.ttp-trip-welcome-steps {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 14px;
}

.ttp-trip-welcome-steps article {
  display: grid;
  align-content: start;
  gap: 8px;
  min-height: 158px;
  padding: 16px;
  border: 1px solid rgba(31, 41, 55, .12);
  border-radius: 8px;
  background: rgba(255, 253, 248, .78);
  box-shadow: 0 12px 28px rgba(15, 23, 42, .06);
}

.ttp-trip-welcome-steps b {
  color: #315f5d;
  font-size: 11px;
  font-weight: 950;
  letter-spacing: .16em;
}

.ttp-trip-welcome-steps h4 {
  margin: 0;
  color: #172033;
  font-size: 17px;
  font-weight: 950;
  line-height: 1.15;
}

.ttp-trip-welcome-steps p {
  margin: 0;
  color: #536071;
  font-size: 13px;
  font-weight: 760;
  line-height: 1.45;
}

.ttp-trip-account-danger {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-top: 14px;
  padding: 14px 16px;
  border: 1px solid rgba(111, 59, 44, .18);
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(111, 59, 44, .06), transparent 60%),
    rgba(255, 253, 248, .78);
}

.ttp-trip-account-danger div {
  display: grid;
  gap: 3px;
}

.ttp-trip-account-danger strong {
  color: #172033;
  font-size: 14px;
  font-weight: 950;
}

.ttp-trip-account-danger span {
  color: #536071;
  font-size: 12px;
  font-weight: 760;
  line-height: 1.4;
}

.ttp-trip-account-danger .ttp-trip-danger {
  flex: 0 0 auto;
  min-height: 34px;
  padding: 8px 11px;
  font-size: 10px;
}

.ttp-trip-map-shell {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 18px;
  margin-top: 24px;
}

.ttp-trip-panel-head {
  display: grid;
  grid-template-columns: minmax(230px, .48fr) minmax(0, 1fr);
  gap: 18px;
  align-items: start;
  margin-top: 24px;
  padding: 18px;
  border: 1px solid rgba(31, 41, 55, .11);
  border-radius: 10px;
  background:
    linear-gradient(135deg, rgba(111, 59, 44, .045), transparent 62%),
    rgba(255, 255, 255, .58);
}

.ttp-trip-panel-head h3 {
  margin: 10px 0 8px;
  color: #172033;
  font-size: clamp(26px, 3.8vw, 42px);
  font-weight: 950;
  letter-spacing: 0;
  line-height: .98;
}

.ttp-trip-panel-head p {
  max-width: 580px;
  margin: 0;
  font-size: 14px;
}

.ttp-trip-panel-head .ttp-trip-compact-list {
  margin-top: 0;
}

.ttp-trip-panel-head .ttp-trip-saved-mini {
  max-width: none;
}

.ttp-trip-route-panel {
  display: grid;
  grid-template-columns: minmax(220px, .55fr) minmax(0, 1fr);
  gap: 18px;
  margin-top: 24px;
  padding: 18px;
  border: 1px solid rgba(31, 41, 55, .12);
  border-radius: 10px;
  background:
    linear-gradient(135deg, rgba(49, 95, 93, .08), transparent 58%),
    rgba(255, 255, 255, .56);
}

.ttp-trip-route-panel h3 {
  margin: 10px 0 8px;
  color: #172033;
  font-size: clamp(24px, 3.5vw, 36px);
  font-weight: 950;
  line-height: 1;
}

.ttp-trip-route-panel p {
  margin: 0;
  font-size: 14px;
}

.ttp-trip-route-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: end;
}

.ttp-trip-name-field,
.ttp-trip-map-field {
  grid-column: 1 / -1;
}

.ttp-trip-route-grid label,
.ttp-trip-end-choice {
  display: grid;
  gap: 7px;
  margin: 0;
  color: #354052;
  font-size: 12px;
  font-weight: 950;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.ttp-trip-route-grid input[type="text"],
.ttp-trip-route-grid select {
  width: 100%;
  min-height: 43px;
  padding: 10px 12px;
  border: 1px solid rgba(31, 41, 55, .16);
  border-radius: 7px;
  background: rgba(255, 253, 248, .84);
  color: #172033;
  font: inherit;
  font-size: 14px;
  font-weight: 750;
  letter-spacing: 0;
  text-transform: none;
}

.ttp-trip-route-grid input[type="text"]:focus,
.ttp-trip-route-grid select:focus {
  border-color: rgba(49, 95, 93, .42);
  box-shadow: 0 0 0 3px rgba(49, 95, 93, .12);
  outline: 0;
}

.ttp-trip-route-grid input[type="text"].has-error {
  border-color: rgba(184, 54, 45, .72);
  background: rgba(255, 245, 243, .92);
  box-shadow: 0 0 0 3px rgba(184, 54, 45, .10);
}

.ttp-trip-end-choice {
  grid-column: 1 / -1;
  padding: 12px;
  border: 1px solid rgba(31, 41, 55, .12);
  border-radius: 8px;
  background: rgba(255, 253, 248, .52);
}

.ttp-trip-end-choice legend {
  padding: 0 6px;
}

.ttp-trip-end-choice label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-right: 16px;
  text-transform: none;
  letter-spacing: 0;
  font-size: 13px;
  font-weight: 850;
}

.ttp-trip-end-choice input {
  accent-color: #315f5d;
}

.ttp-trip-end-address {
  grid-column: 1 / -1;
}

.ttp-trip-route-actions {
  grid-column: 2;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
}

.ttp-trip-route-option {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-height: 46px;
  padding: 10px 12px;
  border: 1px solid rgba(31, 41, 55, .12);
  border-radius: 8px;
  background: rgba(255, 253, 248, .72);
  color: #172033;
  font-size: 12px;
  font-weight: 950;
  letter-spacing: .045em;
  text-transform: uppercase;
}

.ttp-trip-route-option input {
  width: 17px;
  height: 17px;
  margin: 0;
  accent-color: #315f5d;
}

.ttp-trip-route-actions p {
  flex: 1 1 220px;
  color: #536071;
  font-size: 13px;
  font-weight: 750;
}

.ttp-trip-route-discovery {
  grid-column: auto;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 12px 16px;
  align-items: center;
  min-width: 0;
  padding: 14px;
  border: 1px solid rgba(31, 41, 55, .12);
  border-radius: 10px;
  background:
    linear-gradient(135deg, rgba(111, 59, 44, .07), transparent 62%),
    rgba(255, 253, 248, .62);
}

.ttp-trip-discovery-toggle,
.ttp-trip-discovery-radius {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
  margin: 0;
  color: #172033;
  font-size: 12px;
  font-weight: 950;
  letter-spacing: .055em;
  text-transform: uppercase;
}

.ttp-trip-discovery-toggle {
  align-items: flex-start;
}

.ttp-trip-discovery-toggle input {
  flex: 0 0 auto;
  width: 18px;
  height: 18px;
  accent-color: #315f5d;
}

.ttp-trip-discovery-radius {
  display: grid;
  grid-template-columns: minmax(0, auto) minmax(0, 1fr);
}

.ttp-trip-discovery-radius strong {
  color: #315f5d;
  font-size: 15px;
}

.ttp-trip-discovery-radius input {
  min-width: 0;
  width: 100%;
  accent-color: #315f5d;
}

.ttp-trip-route-discovery p {
  grid-column: 1 / -1;
  margin: 0;
  color: #536071;
  font-size: 12px;
  font-weight: 800;
}

.ttp-trip-itinerary {
  grid-column: 1 / -1;
  display: grid;
  gap: 12px;
  margin-top: 2px;
}

.ttp-trip-itinerary:empty {
  display: none;
}

.ttp-trip-itinerary-head,
.ttp-trip-itinerary-summary {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}

.ttp-trip-itinerary-head span {
  color: #6f3b2c;
  font-size: 11px;
  font-weight: 950;
  letter-spacing: .09em;
  text-transform: uppercase;
}

.ttp-trip-itinerary-head strong,
.ttp-trip-itinerary-summary strong,
.ttp-trip-itinerary-summary span,
.ttp-trip-itinerary-summary em {
  display: inline-flex;
  min-height: 30px;
  align-items: center;
  padding: 6px 10px;
  border: 1px solid rgba(31, 41, 55, .12);
  border-radius: 6px;
  background: rgba(255, 253, 248, .78);
  color: #172033;
  font-size: 12px;
  font-style: normal;
  font-weight: 900;
}

.ttp-trip-itinerary-summary em {
  color: #6f3b2c;
}

.ttp-trip-itinerary ol {
  display: grid;
  gap: 8px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.ttp-trip-itinerary li {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  padding: 10px;
  border: 1px solid rgba(31, 41, 55, .10);
  border-radius: 8px;
  background: rgba(255, 253, 248, .62);
}

.ttp-trip-itinerary li b {
  display: grid;
  width: 34px;
  height: 34px;
  place-items: center;
  border-radius: 999px;
  background: #172033;
  color: #fff;
  font-size: 12px;
  font-weight: 950;
}

.ttp-trip-itinerary li.is-start b {
  background: #315f5d;
}

.ttp-trip-itinerary li.is-end b {
  background: #6f3b2c;
}

.ttp-trip-itinerary li strong {
  display: block;
  color: #172033;
  font-size: 14px;
  line-height: 1.15;
}

.ttp-trip-itinerary li small {
  display: block;
  margin-top: 3px;
  color: #536071;
  font-size: 12px;
  line-height: 1.3;
}

.ttp-trip-itinerary-remove {
  display: grid;
  width: 32px;
  height: 32px;
  place-items: center;
  border: 1px solid rgba(111, 59, 44, .20);
  border-radius: 999px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .96), rgba(255, 253, 248, .76)),
    #fffdf8;
  color: #6f3b2c;
  cursor: pointer;
  font: inherit;
  font-size: 22px;
  font-weight: 950;
  line-height: 1;
  box-shadow: 0 10px 20px rgba(15, 23, 42, .08);
  transition: transform .16s ease, border-color .16s ease, color .16s ease, box-shadow .16s ease;
}

.ttp-trip-itinerary-remove:hover,
.ttp-trip-itinerary-remove:focus {
  transform: translateY(-1px);
  border-color: rgba(111, 59, 44, .42);
  color: #172033;
  outline: 0;
  box-shadow: 0 14px 28px rgba(15, 23, 42, .14);
}

.ttp-trip-itinerary li.is-start,
.ttp-trip-itinerary li.is-end {
  grid-template-columns: 34px minmax(0, 1fr);
}

.ttp-trip-map {
  position: relative;
  min-height: 430px;
  overflow: hidden;
  border: 1px solid rgba(31, 41, 55, .13);
  border-radius: 10px;
  background: #e7ebe8;
}

.ttp-trip-map iframe {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 430px;
  border: 0;
}

.ttp-trip-map-note,
.ttp-trip-map-empty {
  position: absolute;
  left: 14px;
  bottom: 14px;
  max-width: calc(100% - 28px);
  padding: 8px 10px;
  border: 1px solid rgba(31, 41, 55, .12);
  border-radius: 6px;
  background: rgba(255, 253, 248, .88);
  color: #172033;
  font-size: 12px;
  font-weight: 900;
}

.ttp-trip-map-empty {
  inset: 0;
  display: grid;
  max-width: none;
  place-items: center;
  border: 0;
  border-radius: 0;
  background: transparent;
  font-size: 15px;
}

.ttp-trip-list {
  display: grid;
  align-content: start;
  gap: 12px;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 310px), 1fr));
  max-height: none;
  overflow: visible;
  padding-right: 0;
}

.ttp-trip-page-group {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 14px;
  border: 1px solid rgba(31, 41, 55, .12);
  border-radius: 9px;
  background:
    linear-gradient(135deg, rgba(111, 59, 44, .07), transparent 62%),
    rgba(255, 253, 248, .68);
}

.ttp-trip-page-group div {
  display: grid;
  gap: 4px;
}

.ttp-trip-page-group span {
  width: fit-content;
  margin: 0;
  padding: 5px 8px;
  border: 1px solid rgba(111, 59, 44, .18);
  border-radius: 5px;
  color: #6f3b2c;
  font-size: 10px;
  font-weight: 950;
  letter-spacing: .09em;
  text-transform: uppercase;
}

.ttp-trip-page-group strong {
  color: #172033;
  font-size: 17px;
  font-weight: 950;
  line-height: 1.15;
}

.ttp-trip-page-group small {
  color: #536071;
  font-size: 12px;
  font-weight: 850;
}

.ttp-trip-page-group label {
  display: inline-flex;
  flex: 0 0 auto;
  align-items: center;
  gap: 8px;
  color: #172033;
  font-size: 12px;
  font-weight: 950;
  letter-spacing: .055em;
  text-transform: uppercase;
}

.ttp-trip-page-group input {
  width: 18px;
  height: 18px;
  accent-color: #315f5d;
}

.ttp-trip-location-card {
  display: grid;
  gap: 14px;
  padding: 16px;
  border: 1px solid rgba(31, 41, 55, .12);
  border-radius: 9px;
  background: rgba(255, 253, 248, .74);
  transition: border-color .18s ease, background .18s ease, box-shadow .18s ease;
}

.ttp-trip-location-card.is-visited {
  border-color: rgba(49, 95, 93, .30);
  background:
    linear-gradient(135deg, rgba(49, 95, 93, .08), transparent 54%),
    rgba(255, 253, 248, .78);
}

.ttp-trip-location-card.is-route-excluded {
  opacity: .68;
}

.ttp-trip-location-card span {
  display: inline-flex;
  width: fit-content;
  margin-bottom: 8px;
  padding: 6px 9px;
  border: 1px solid rgba(111, 59, 44, .18);
  border-radius: 5px;
  color: #6f3b2c;
  font-size: 10px;
  font-weight: 950;
  letter-spacing: .09em;
  text-transform: uppercase;
}

.ttp-trip-location-card h3 {
  margin: 0;
  color: #172033;
  font-size: 20px;
  line-height: 1.08;
}

.ttp-trip-location-card p {
  margin: 6px 0 0;
  font-size: 14px;
}

.ttp-trip-saved-organizer {
  display: grid;
  gap: 14px;
}

.ttp-trip-saved-section {
  overflow: hidden;
  border: 1px solid rgba(31, 41, 55, .13);
  border-radius: 10px;
  background: rgba(255, 253, 248, .72);
}

.ttp-trip-saved-section > header,
.ttp-trip-article-group > header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 14px;
  border-bottom: 1px solid rgba(31, 41, 55, .10);
  background: rgba(255, 255, 255, .62);
}

.ttp-trip-saved-section > header strong,
.ttp-trip-article-group > header strong {
  display: block;
  color: #172033;
  font-size: 15px;
  font-weight: 950;
  line-height: 1.1;
}

.ttp-trip-saved-section > header span,
.ttp-trip-article-group > header span {
  display: block;
  margin-top: 3px;
  color: #647084;
  font-size: 12px;
  font-weight: 750;
  line-height: 1.3;
}

.ttp-trip-saved-section-body {
  display: grid;
  gap: 8px;
  padding: 10px;
}

.ttp-trip-article-group {
  overflow: hidden;
  border: 1px solid rgba(31, 41, 55, .10);
  border-radius: 8px;
  background: rgba(255, 255, 255, .48);
}

.ttp-trip-article-group + .ttp-trip-article-group {
  margin-top: 8px;
}

.ttp-trip-article-group > header {
  padding: 10px 12px;
}

.ttp-trip-article-group label,
.ttp-trip-saved-row-controls label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: #354052;
  font-size: 10px;
  font-weight: 950;
  letter-spacing: .06em;
  text-transform: uppercase;
  white-space: nowrap;
}

.ttp-trip-article-group input,
.ttp-trip-saved-row-controls input {
  width: 15px;
  height: 15px;
  accent-color: #315f5d;
}

.ttp-trip-saved-row {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr) auto auto;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border: 1px solid rgba(31, 41, 55, .10);
  border-radius: 8px;
  background: rgba(255, 253, 248, .74);
}

.ttp-trip-article-group .ttp-trip-saved-row {
  border-width: 1px 0 0;
  border-radius: 0;
  background: transparent;
}

.ttp-trip-saved-row.is-route-excluded {
  opacity: .68;
}

.ttp-trip-saved-row.is-visited {
  background:
    linear-gradient(90deg, rgba(49, 95, 93, .08), transparent 44%),
    rgba(255, 253, 248, .82);
}

.ttp-trip-saved-index {
  display: grid;
  width: 30px;
  height: 30px;
  place-items: center;
  border: 1px solid rgba(49, 95, 93, .20);
  border-radius: 50%;
  color: #315f5d;
  font-size: 10px;
  font-weight: 950;
  letter-spacing: .05em;
}

.ttp-trip-saved-row-main {
  min-width: 0;
}

.ttp-trip-saved-row-title {
  display: flex;
  min-width: 0;
  align-items: center;
  gap: 8px;
}

.ttp-trip-saved-row-title b {
  flex: 0 0 auto;
  padding: 4px 7px;
  border: 1px solid rgba(111, 59, 44, .16);
  border-radius: 5px;
  color: #6f3b2c;
  font-size: 9px;
  font-weight: 950;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.ttp-trip-saved-row-title strong {
  min-width: 0;
  overflow: hidden;
  color: #172033;
  font-size: 14px;
  font-weight: 950;
  line-height: 1.15;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ttp-trip-saved-row p,
.ttp-trip-saved-row small {
  display: block;
  min-width: 0;
  margin: 3px 0 0;
  overflow: hidden;
  color: #647084;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.28;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ttp-trip-saved-row small {
  color: #7a6f60;
  font-size: 11px;
}

.ttp-trip-saved-row-controls,
.ttp-trip-saved-row-actions {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.ttp-trip-saved-row-actions a,
.ttp-trip-saved-row-actions button {
  min-height: 30px;
  padding: 6px 9px;
  border: 1px solid rgba(31, 41, 55, .12);
  border-radius: 6px;
  background: rgba(255, 255, 255, .74);
  color: #354052;
  cursor: pointer;
  font-size: 11px;
  font-weight: 900;
  line-height: 1;
  text-decoration: none;
}

.ttp-trip-saved-row-actions button {
  color: #7a2d23;
}

.ttp-trip-saved-empty {
  margin: 0;
  padding: 12px;
  color: #647084;
  font-size: 13px;
  font-weight: 750;
}

@media (max-width: 760px) {
  .ttp-trip-saved-row {
    grid-template-columns: 30px minmax(0, 1fr);
  }

  .ttp-trip-saved-row-controls,
  .ttp-trip-saved-row-actions {
    grid-column: 2;
    flex-wrap: wrap;
  }

  .ttp-trip-saved-section > header,
  .ttp-trip-article-group > header {
    align-items: flex-start;
    flex-direction: column;
  }
}

.ttp-trip-stop-description {
  color: #536071;
  font-size: 13px !important;
  line-height: 1.45;
}

.ttp-trip-stop-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 10px;
}

.ttp-trip-stop-meta span {
  margin: 0;
  border-color: rgba(49, 95, 93, .18);
  color: #315f5d;
}

.ttp-trip-card-main {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 12px;
}

.ttp-trip-stop-number {
  display: grid;
  width: 34px;
  height: 34px;
  place-items: center;
  border: 1px solid rgba(31, 41, 55, .16);
  border-radius: 999px;
  background: #172033;
  color: #fff;
  font-size: 13px;
  font-weight: 950;
  line-height: 1;
}

.ttp-trip-visited,
.ttp-trip-map-toggle {
  display: inline-flex;
  width: fit-content;
  align-items: center;
  gap: 8px;
  margin-top: 12px;
  color: #354052;
  font-size: 12px;
  font-weight: 950;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.ttp-trip-visited input,
.ttp-trip-map-toggle input {
  width: 17px;
  height: 17px;
  accent-color: #315f5d;
}

.ttp-trip-map-toggle {
  color: #172033;
}

.ttp-trip-notes-label {
  display: block;
  margin-top: 12px;
  color: #6f3b2c;
  font-size: 11px;
  font-weight: 950;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.ttp-trip-notes {
  display: block;
  width: 100%;
  min-height: 62px;
  margin-top: 6px;
  padding: 10px 11px;
  resize: vertical;
  border: 1px solid rgba(31, 41, 55, .14);
  border-radius: 7px;
  background: rgba(255, 255, 255, .72);
  color: #172033;
  font: inherit;
  font-size: 13px;
  line-height: 1.4;
}

.ttp-trip-notes:focus {
  border-color: rgba(49, 95, 93, .42);
  box-shadow: 0 0 0 3px rgba(49, 95, 93, .12);
  outline: 0;
}

.ttp-trip-card-actions {
  display: flex;
  flex-wrap: wrap;
  align-self: end;
  align-items: center;
  align-content: flex-start;
  gap: 8px;
}

.ttp-trip-card-actions a,
.ttp-trip-card-actions button {
  display: inline-flex;
  flex: 0 0 auto;
  min-height: 32px;
  align-items: center;
  align-self: center;
  justify-content: center;
  padding: 7px 10px;
  border: 1px solid rgba(31, 41, 55, .14);
  border-radius: 6px;
  background: rgba(255, 255, 255, .72);
  color: #172033;
  font: inherit;
  font-size: 12px;
  font-weight: 900;
  text-decoration: none;
  cursor: pointer;
}

.ttp-trip-empty {
  margin: 0;
  padding: 18px;
  border: 1px dashed rgba(31, 41, 55, .22);
  border-radius: 8px;
}

.ttp-trip-empty strong {
  display: block;
  color: #172033;
  font-size: 16px;
  font-weight: 950;
  line-height: 1.2;
}

.ttp-trip-empty span {
  display: block;
  margin-top: 6px;
  color: #536071;
  font-size: 13px;
  font-weight: 800;
  line-height: 1.45;
}

.ttp-trip-map-marker {
  display: grid;
  place-items: center;
  border: 2px solid #fffaf3;
  border-radius: 999px;
  background: #172033;
  box-shadow: 0 10px 22px rgba(15, 23, 42, .24);
}

.ttp-trip-map-marker.is-start {
  background: #315f5d;
}

.ttp-trip-map-marker.is-end {
  background: #6f3b2c;
}

.ttp-trip-map-marker.is-discovery {
  border-color: #fff;
  background: #d89a2b;
  box-shadow: 0 10px 22px rgba(111, 59, 44, .30);
}

.ttp-trip-map-marker.is-discovery.is-added {
  background: #315f5d;
}

.ttp-trip-map-marker span {
  display: grid;
  width: 100%;
  height: 100%;
  place-items: center;
  border-radius: inherit;
  color: #fff;
  font-size: 13px;
  font-weight: 950;
}

.ttp-trip-map-marker.is-discovery span {
  font-size: 16px;
  line-height: 1;
}

.ttp-trip-discovery-popup .leaflet-popup-content-wrapper {
  border-radius: 16px;
  background: #fffdf8;
  box-shadow: 0 18px 44px rgba(15, 23, 42, .20);
}

.ttp-trip-discovery-popup .leaflet-popup-content {
  margin: 14px;
}

.ttp-trip-stop-popup .leaflet-popup-content-wrapper {
  border-radius: 14px;
  background: #fffdf8;
  box-shadow: 0 18px 44px rgba(15, 23, 42, .20);
}

.ttp-trip-stop-popup .leaflet-popup-content {
  margin: 12px;
}

.ttp-trip-map-stop-card {
  min-width: 218px;
  color: #172033;
}

.ttp-trip-map-stop-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 8px;
}

.ttp-trip-map-stop-meta span,
.ttp-trip-map-stop-meta b {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 5px 8px;
  border: 1px solid rgba(49, 95, 93, .16);
  border-radius: 999px;
  background: rgba(255, 253, 248, .90);
  color: #315f5d;
  font-size: 10px;
  font-weight: 950;
  letter-spacing: .07em;
  line-height: 1;
  text-transform: uppercase;
}

.ttp-trip-map-stop-meta b {
  border-color: rgba(111, 59, 44, .16);
  color: #6f3b2c;
}

.ttp-trip-map-stop-card strong {
  display: block;
  color: #172033;
  font-size: 15px;
  font-weight: 950;
  line-height: 1.15;
}

.ttp-trip-map-stop-card p,
.ttp-trip-map-stop-card small {
  display: block;
  margin: 7px 0 0;
  color: #536071;
  font-size: 12px;
  font-weight: 750;
  line-height: 1.35;
}

.ttp-trip-popup-nav {
  display: flex;
  gap: 7px;
  margin-top: 11px;
  padding-top: 10px;
  border-top: 1px solid rgba(31, 41, 55, .10);
}

.ttp-trip-popup-nav a {
  display: grid;
  min-width: 54px;
  min-height: 52px;
  place-items: center;
  padding: 7px 6px 6px;
  border: 1px solid rgba(31, 41, 55, .12);
  border-radius: 8px;
  background: rgba(255, 255, 255, .78);
  color: #172033;
  font-size: 10px;
  font-weight: 900;
  line-height: 1;
  text-decoration: none;
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}

.ttp-trip-popup-nav a:hover,
.ttp-trip-popup-nav a:focus {
  border-color: rgba(49, 95, 93, .28);
  box-shadow: 0 10px 20px rgba(15, 23, 42, .12);
  outline: 0;
  transform: translateY(-1px);
}

.ttp-trip-popup-nav img {
  display: block;
  width: 22px;
  height: 22px;
  margin-bottom: 5px;
  object-fit: contain;
}

.ttp-trip-popup-nav .is-google span {
  color: #4285f4;
}

.ttp-trip-popup-nav .is-waze span,
.ttp-trip-popup-nav .is-apple span {
  color: #35bdf4;
}

.ttp-trip-discovery-card {
  min-width: 230px;
  color: #172033;
}

.ttp-trip-discovery-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 8px;
}

.ttp-trip-discovery-meta span,
.ttp-trip-discovery-meta b {
  display: inline-flex;
  align-items: center;
  min-height: 26px;
  padding: 5px 8px;
  border: 1px solid rgba(49, 95, 93, .16);
  border-radius: 999px;
  background: rgba(255, 253, 248, .88);
  color: #315f5d;
  font-size: 10px;
  font-weight: 950;
  letter-spacing: .07em;
  text-transform: uppercase;
}

.ttp-trip-discovery-meta b {
  border-color: rgba(111, 59, 44, .16);
  color: #6f3b2c;
}

.ttp-trip-discovery-card strong {
  display: block;
  font-size: 16px;
  font-weight: 950;
  line-height: 1.1;
}

.ttp-trip-discovery-card p {
  margin: 7px 0 0;
  color: #536071;
  font-size: 12px;
  line-height: 1.4;
}

.ttp-trip-discovery-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin-top: 12px;
}

.ttp-trip-discovery-actions a,
.ttp-trip-discovery-actions button {
  display: inline-flex;
  min-height: 32px;
  align-items: center;
  padding: 7px 10px;
  border: 1px solid rgba(31, 41, 55, .14);
  border-radius: 6px;
  background: #172033;
  color: #fff;
  font: inherit;
  font-size: 11px;
  font-weight: 950;
  letter-spacing: .04em;
  line-height: 1;
  text-decoration: none;
  text-transform: uppercase;
  cursor: pointer;
}

.ttp-trip-discovery-actions a {
  background: rgba(255, 253, 248, .82);
  color: #172033;
}

.ttp-state-map-section {
  width: min(100%, var(--ttp-wide, 1180px));
  margin: 0 auto clamp(26px, 5vw, 54px);
  padding: clamp(18px, 3vw, 30px);
  border: 1px solid rgba(31, 41, 55, .12);
  border-radius: 14px;
  background:
    linear-gradient(90deg, #d99d2b, #6f3b2c, #315f5d) top / 100% 4px no-repeat,
    linear-gradient(135deg, rgba(255, 253, 248, .96), rgba(248, 250, 252, .88)),
    repeating-linear-gradient(0deg, transparent 0 35px, rgba(31, 41, 55, .025) 35px 36px);
  box-shadow: 0 24px 58px rgba(15, 23, 42, .10);
}

.ttp-state-map-copy {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px 20px;
  align-items: end;
  margin-bottom: 16px;
}

.ttp-state-map-copy .ttp-trip-kicker {
  grid-column: 1 / -1;
  justify-self: start;
}

.ttp-state-map-copy h2 {
  margin: 0;
  max-width: 760px;
  color: #172033;
  font-size: clamp(28px, 4vw, 48px);
  line-height: 1;
  font-weight: 950;
  letter-spacing: 0;
}

.ttp-state-map-copy p {
  grid-column: 1;
  margin: 0;
  max-width: 760px;
  color: #536071;
  font-size: 16px;
  font-weight: 750;
  line-height: 1.55;
}

.ttp-state-map-copy a {
  grid-column: 2;
  grid-row: 2 / span 2;
  align-self: center;
  display: inline-flex;
  min-height: 40px;
  align-items: center;
  padding: 10px 13px;
  border: 1px solid rgba(31, 41, 55, .15);
  border-radius: 8px;
  background: #172033;
  color: #fff;
  font-size: 12px;
  font-weight: 950;
  letter-spacing: .05em;
  line-height: 1;
  text-decoration: none;
  text-transform: uppercase;
}

.ttp-state-map-shell {
  overflow: hidden;
  border: 1px solid rgba(31, 41, 55, .14);
  border-radius: 12px;
  background: #f8fafc;
}

.ttp-state-archive-map {
  min-height: clamp(300px, 42vw, 460px);
}

.ttp-state-map-popup .leaflet-popup-content {
  margin: 14px;
}

.ttp-state-map-card {
  min-width: min(260px, 72vw);
}

.ttp-state-map-empty {
  display: grid;
  gap: 6px;
  padding: 18px;
  border: 1px dashed rgba(31, 41, 55, .20);
  border-radius: 10px;
  color: #536071;
  font-weight: 800;
}

.ttp-state-map-empty strong {
  color: #172033;
  font-size: 18px;
  font-weight: 950;
}

.ttp-trip-travel-bar {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  gap: 10px;
  margin: 18px 0 12px;
}

.ttp-trip-save-map-inline {
  flex: 0 0 auto;
  min-height: 42px;
  padding: 0 16px;
  border: 1px solid rgba(31, 41, 55, .16);
  border-radius: 7px;
  background: #172033;
  color: #fff;
  cursor: pointer;
  font: inherit;
  font-size: 11px;
  font-weight: 950;
  letter-spacing: .08em;
  text-transform: uppercase;
  box-shadow: 0 10px 22px rgba(15, 23, 42, .10);
}

.ttp-trip-save-map-inline:hover,
.ttp-trip-save-map-inline:focus {
  border-color: rgba(31, 41, 55, .28);
  background: #263144;
  outline: 0;
}

.ttp-trip-state-map-wrap {
  position: relative;
}

.ttp-trip-map-share {
  position: absolute;
  right: 14px;
  bottom: 14px;
  z-index: 4;
  display: inline-flex;
  gap: 6px;
  padding: 5px;
  border: 1px solid rgba(31, 41, 55, .12);
  border-radius: 999px;
  background: rgba(255, 253, 248, .86);
  box-shadow: 0 12px 26px rgba(15, 23, 42, .14);
  backdrop-filter: blur(8px);
}

.ttp-trip-map-share-icon {
  display: grid;
  width: 28px;
  height: 28px;
  place-items: center;
  border-radius: 999px;
  color: #fff;
  font-size: 14px;
  font-weight: 950;
  line-height: 1;
  text-decoration: none;
}

.ttp-trip-map-share-icon:hover,
.ttp-trip-map-share-icon:focus {
  transform: translateY(-1px);
  outline: 0;
}

.ttp-trip-map-share-icon.is-facebook {
  background: #1877f2;
  font-family: Arial, Helvetica, sans-serif;
  font-size: 18px;
}

.ttp-trip-map-share-icon.is-x {
  background: #000;
  font-family: Arial, Helvetica, sans-serif;
  font-size: 12px;
}

.ttp-trip-states-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 16px 0;
}

.ttp-trip-states-summary span {
  display: inline-flex;
  min-height: 38px;
  align-items: center;
  gap: 7px;
  padding: 8px 12px;
  border: 1px solid rgba(31, 41, 55, .13);
  border-radius: 999px;
  background: rgba(255, 255, 255, .66);
  color: #536071;
  font-size: 12px;
  font-weight: 850;
}

.ttp-trip-states-summary strong {
  color: #172033;
  font-size: 17px;
  font-weight: 950;
}

.ttp-trip-states-summary p {
  flex: 1 1 100%;
  margin: 0;
  color: #536071;
  font-size: 14px;
}

.ttp-trip-state-map {
  position: relative;
  display: block;
  padding: clamp(12px, 2vw, 22px);
  border: 1px solid rgba(31, 41, 55, .12);
  border-radius: 10px;
  background:
    radial-gradient(circle at 18% 20%, rgba(48, 87, 93, .10), transparent 30%),
    linear-gradient(180deg, rgba(250, 251, 248, .84), rgba(246, 241, 232, .62)),
    repeating-linear-gradient(0deg, transparent 0 35px, rgba(31, 41, 55, .035) 35px 36px),
    #f8f4ed;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .72);
}

.ttp-trip-state-map.is-loading {
  min-height: 360px;
}

.ttp-real-state-map {
  display: block;
  width: 100%;
  height: auto;
  max-width: 100%;
  overflow: hidden;
  shape-rendering: geometricPrecision;
  text-rendering: geometricPrecision;
}

.ttp-real-state-map .state path,
.ttp-real-state-map .state circle {
  fill: #fffdfa;
  stroke: rgba(38, 49, 68, .68);
  stroke-width: 1.1;
  stroke-linecap: round;
  stroke-linejoin: round;
  vector-effect: non-scaling-stroke;
  shape-rendering: geometricPrecision;
  cursor: pointer;
  filter: none;
  transition: fill .16s ease, stroke .16s ease, filter .16s ease, opacity .16s ease;
}

.ttp-real-state-map .state text {
  fill: #172033;
  font-size: 20px;
  font-weight: 950;
  letter-spacing: .04em;
  pointer-events: none;
  text-anchor: middle;
}

.ttp-real-state-map .state path:hover,
.ttp-real-state-map .state path:focus,
.ttp-real-state-map .state circle:hover,
.ttp-real-state-map .state circle:focus {
  fill: #f0f6f5;
  stroke: #315f5d;
  outline: 0;
  filter: none;
}

.ttp-real-state-map .state .is-visited {
  fill: #315f5d;
  stroke: #1d3f3e;
  filter: none;
}

.ttp-real-state-map .state .is-visited:nth-child(3n) {
  fill: #6f3b2c;
  stroke: #542a1e;
}

.ttp-real-state-map .state .is-visited:nth-child(4n) {
  fill: #172033;
  stroke: #0f172a;
}

.ttp-real-state-map .state .is-visited + text,
.ttp-real-state-map .state path.is-visited ~ text {
  fill: #fff;
}

.ttp-real-state-map .borders {
  fill: none;
  stroke: #fffaf3;
  stroke-width: 1.1;
  pointer-events: none;
}

.ttp-real-state-map .separator1 {
  fill: none;
  stroke: rgba(111, 59, 44, .40);
  stroke-width: 2;
  pointer-events: none;
}

.ttp-trip-state-map button,
.ttp-trip-state-map span {
  grid-row: var(--state-row);
  grid-column: var(--state-col);
  display: grid;
  min-width: 0;
  min-height: 44px;
  place-items: center;
  padding: 7px 5px;
  border: 1px solid rgba(31, 41, 55, .14);
  border-radius: 12px;
  background: rgba(255, 255, 255, .72);
  color: #536071;
  cursor: pointer;
  font: inherit;
  text-align: center;
  transition: transform .16s ease, background .16s ease, border-color .16s ease, box-shadow .16s ease;
}

.ttp-trip-state-map span {
  cursor: default;
}

.ttp-trip-state-map button:hover,
.ttp-trip-state-map button:focus {
  transform: translateY(-1px);
  border-color: rgba(49, 95, 93, .32);
  outline: 0;
  box-shadow: 0 12px 22px rgba(15, 23, 42, .10);
}

.ttp-trip-state-map .is-visited {
  border-color: rgba(49, 95, 93, .38);
  background:
    linear-gradient(135deg, rgba(49, 95, 93, .94), rgba(111, 59, 44, .86)),
    #315f5d;
  color: #fff;
  box-shadow: 0 12px 22px rgba(49, 95, 93, .16);
}

.ttp-trip-state-map strong {
  display: block;
  color: inherit;
  font-size: 13px;
  font-weight: 950;
  letter-spacing: .06em;
  line-height: 1;
}

.ttp-trip-state-map small {
  display: none;
}

.ttp-trip-states-status {
  margin: 12px 0 0;
  color: #536071;
  font-size: 13px;
  font-weight: 800;
}

.ttp-trip-travel-tabs {
  display: flex;
  flex: 1 1 520px;
  flex-wrap: wrap;
  gap: 0;
  margin: 0;
  border-top: 1px solid rgba(31, 41, 55, .12);
  border-bottom: 1px solid rgba(31, 41, 55, .12);
  background: rgba(255, 253, 248, .64);
}

.ttp-trip-travel-tabs button {
  position: relative;
  min-height: 42px;
  padding: 12px 14px;
  border: 0;
  border-right: 1px solid rgba(31, 41, 55, .10);
  background: transparent;
  color: #596476;
  cursor: pointer;
  font: inherit;
  font-size: 11px;
  font-weight: 950;
  letter-spacing: .08em;
  line-height: 1;
  text-transform: uppercase;
}

.ttp-trip-travel-tabs button::after {
  content: "";
  position: absolute;
  right: 13px;
  bottom: -1px;
  left: 13px;
  height: 3px;
  background: transparent;
}

.ttp-trip-travel-tabs button.is-active {
  color: #172033;
  background: rgba(255, 255, 255, .70);
}

.ttp-trip-travel-tabs button.is-active::after {
  background: linear-gradient(90deg, #6f3b2c, #315f5d);
}

.ttp-trip-state-map.is-region-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  min-height: 0;
}

.ttp-region-svg-map {
  display: block;
  width: 100%;
  height: clamp(360px, 52vw, 620px);
  min-height: 0;
  max-width: 100%;
  overflow: hidden;
  cursor: grab;
  shape-rendering: geometricPrecision;
  text-rendering: geometricPrecision;
  touch-action: none;
  user-select: none;
}

.ttp-trip-state-map.is-panning .ttp-region-svg-map {
  cursor: grabbing;
}

.ttp-region-ocean {
  fill: #e8f0f1;
}

.ttp-region path {
  fill: #fbf7ee;
  stroke: rgba(84, 93, 103, .58);
  stroke-width: 1.15;
  stroke-linecap: round;
  stroke-linejoin: round;
  vector-effect: non-scaling-stroke;
  shape-rendering: geometricPrecision;
  cursor: pointer;
  filter: none;
  transition: fill .16s ease, stroke .16s ease, filter .16s ease, transform .16s ease;
}

.ttp-region text {
  fill: #172033;
  font-size: 18px;
  font-weight: 950;
  letter-spacing: .04em;
  pointer-events: none;
  text-anchor: middle;
}

.ttp-region:hover path,
.ttp-region:focus path {
  fill: #f1eee5;
  stroke: #305d62;
  outline: 0;
  filter: none;
}

.ttp-region:focus {
  outline: 0;
}

.ttp-region.is-visited path {
  fill: #305d62;
  stroke: #18393d;
  filter: none;
}

.ttp-region.is-visited:nth-child(3n) path {
  fill: #7a4334;
  stroke: #52281e;
}

.ttp-region.is-visited:nth-child(4n) path {
  fill: #1d2738;
  stroke: #101725;
}

.ttp-region.is-visited:nth-child(5n) path {
  fill: #9b7a36;
  stroke: #604819;
}

.ttp-region.is-visited text {
  fill: #fff;
}

.ttp-map-zoom-controls {
  position: absolute;
  top: 14px;
  right: 14px;
  z-index: 3;
  display: grid;
  gap: 6px;
  padding: 6px;
  border: 1px solid rgba(31, 41, 55, .14);
  border-radius: 8px;
  background: rgba(255, 253, 248, .88);
  box-shadow: 0 14px 30px rgba(15, 23, 42, .12);
  backdrop-filter: blur(10px);
}

.ttp-map-zoom-controls button {
  width: 34px;
  min-width: 34px;
  height: 34px;
  min-height: 34px;
  padding: 0;
  border: 1px solid rgba(31, 41, 55, .15);
  border-radius: 6px;
  background: #fffdf8;
  color: #172033;
  cursor: pointer;
  font: inherit;
  font-size: 15px;
  font-weight: 950;
  line-height: 1;
  text-align: center;
  box-shadow: none;
}

.ttp-map-zoom-controls button[data-ttp-travel-map-zoom="fit"] {
  font-size: 10px;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.ttp-map-zoom-controls button:hover,
.ttp-map-zoom-controls button:focus {
  border-color: rgba(48, 93, 98, .40);
  background: #f5f0e7;
  outline: 0;
  transform: none;
  box-shadow: none;
}

.ttp-map-zoom-controls button:disabled {
  opacity: .42;
  cursor: default;
}

.ttp-trip-state-map.is-region-grid button {
  min-height: 76px;
  align-content: center;
  gap: 5px;
  border-radius: 9px;
}

.ttp-trip-state-map.is-region-grid small {
  display: block;
  max-width: 100%;
  overflow: hidden;
  color: inherit;
  font-size: 11px;
  font-weight: 850;
  line-height: 1.18;
  text-overflow: ellipsis;
}

.ttp-trip-shared-states .ttp-trip-state-map {
  margin: 22px 0;
}

@media (max-width: 760px) {
  .ttp-trip-map-shell,
  .ttp-trip-panel-head,
  .ttp-trip-dashboard,
  .ttp-trip-route-panel,
  .ttp-trip-route-grid {
    grid-template-columns: 1fr;
  }

  .ttp-trip-planner-empty.is-phone-landing {
    grid-template-columns: 1fr;
    padding: 22px 18px 28px;
  }

  .ttp-trip-empty-copy h2 {
    max-width: 11.5ch;
    font-size: clamp(34px, 12vw, 52px);
  }

  .ttp-trip-hero-banner {
    grid-template-columns: 1fr;
    min-height: 0;
  }

  .ttp-trip-hero-copy {
    padding: 28px 22px 32px;
  }

  .ttp-trip-hero-art {
    display: none;
  }

  .ttp-trip-user-menu {
    top: 10px;
    right: 10px;
  }

  .ttp-trip-user-dropdown {
    width: min(236px, calc(100vw - 28px));
  }

  .ttp-trip-tabs {
    width: 100%;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .ttp-trip-tabs button {
    min-width: 0;
    border-bottom: 1px solid rgba(31, 41, 55, .10);
  }

  .ttp-trip-travel-tabs {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .ttp-trip-welcome-steps {
    grid-template-columns: 1fr;
  }

  .ttp-trip-dashboard-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .ttp-trip-welcome-copy h3 {
    max-width: 100%;
  }

  .ttp-trip-save-map-inline {
    flex: 1 1 100%;
  }

  .ttp-trip-travel-tabs button {
    min-width: 0;
    border-bottom: 1px solid rgba(31, 41, 55, .10);
  }

  .ttp-trip-state-map.is-region-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .ttp-trip-route-actions {
    grid-column: auto;
  }

  .ttp-trip-route-discovery,
  .ttp-trip-discovery-radius {
    grid-template-columns: 1fr;
  }

  .ttp-state-map-copy {
    grid-template-columns: 1fr;
  }

  .ttp-state-map-copy p,
  .ttp-state-map-copy a {
    grid-column: auto;
    grid-row: auto;
  }

  .ttp-trip-map,
  .ttp-trip-map iframe {
    min-height: 320px;
  }

  .ttp-trip-list {
    max-height: none;
  }

  .ttp-trip-auth-dialog h2,
  .ttp-trip-planner h2 {
    max-width: 100%;
    font-size: clamp(34px, 9vw, 46px);
  }

  .ttp-trip-map-share {
    right: 10px;
    bottom: 10px;
  }

  .ttp-trip-map-share-icon {
    width: 26px;
    height: 26px;
  }

  .ttp-trip-save-page-panel,
  .ttp-trip-page-group {
    display: grid;
  }

  .ttp-trip-page-group label {
    flex: 1 1 auto;
  }
}

@media (max-width: 560px) {
  html.ttp-trip-auth-open,
  html.ttp-trip-auth-open body {
    overflow: hidden;
  }

  .ttp-trip-auth-modal,
  .ttp-trip-map-picker {
    align-items: flex-start;
    padding: 12px;
    overflow: auto;
  }

  .ttp-trip-auth-dialog {
    width: min(100%, 420px);
    max-height: calc(100svh - 24px);
    padding: 22px 18px;
    overflow: auto;
    border-radius: 18px;
  }

  .ttp-trip-auth-close {
    top: 10px;
    right: 10px;
  }

  .ttp-trip-auth-dialog h2 {
    margin: 10px 0;
    font-size: clamp(30px, 9vw, 42px);
    line-height: .98;
  }

  .ttp-trip-auth-dialog p {
    font-size: 15px;
    line-height: 1.42;
  }

  .ttp-trip-auth-actions {
    gap: 9px;
    margin-top: 16px;
  }

  .ttp-trip-provider,
  .ttp-trip-primary,
  .ttp-trip-register {
    width: 100%;
    min-height: 46px;
    padding: 11px 13px;
    font-size: 12px;
  }
}
