:root {
  font-family: Arial, "Malgun Gothic", sans-serif;
  color: #16313e;
  background: #fbfcfc;
}

/* TripBusan customer mobile shell */
.site-footer,
.corporate-footer {
  display: none !important;
}

.has-tripbusan-bottom-nav,
.customer-app-page,
.explore-mobile-detail-page {
  padding-bottom: 86px;
}

.has-tripbusan-bottom-nav.has-tripbusan-business-strip,
.customer-app-page.has-tripbusan-business-strip,
.explore-mobile-detail-page.has-tripbusan-business-strip {
  padding-bottom: 86px;
}

.customer-simple-header {
  position: sticky;
  top: 0;
  z-index: 40;
  background: rgba(255, 255, 255, 0.94);
  backdrop-filter: blur(14px);
}

.customer-simple-header nav,
.explore-baemin-page .site-header nav {
  display: none !important;
}

.tripbusan-bottom-nav,
.mobile-bottom-nav {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 90;
  display: grid;
  gap: 4px;
  padding: 8px 10px calc(8px + env(safe-area-inset-bottom));
  border-top: 1px solid rgba(9, 51, 57, 0.12);
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 -10px 30px rgba(5, 33, 38, 0.12);
  backdrop-filter: blur(18px);
}

.tripbusan-bottom-nav {
  grid-template-columns: repeat(6, minmax(0, 1fr));
}

.mobile-bottom-nav {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.tripbusan-bottom-nav a,
.mobile-bottom-nav a {
  display: flex;
  min-height: 54px;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 3px;
  color: #24484e;
  text-decoration: none;
  border-radius: 16px;
  font-size: 0.72rem;
  font-weight: 800;
}

.tripbusan-bottom-nav a span,
.mobile-bottom-nav a span {
  font-size: 1.25rem;
  line-height: 1;
}

.tripbusan-bottom-nav a.active,
.mobile-bottom-nav a:hover,
.mobile-bottom-nav a:focus-visible {
  color: #007d80;
  background: #e8fbf6;
}

.tripbusan-business-type-strip {
  display: none !important;
  position: fixed;
  left: 0;
  right: 0;
  bottom: calc(74px + env(safe-area-inset-bottom));
  z-index: 91;
  display: grid;
  gap: 10px;
  padding: 10px 10px 12px;
  border-top: 1px solid rgba(16, 24, 40, 0.08);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(248, 252, 251, 0.98) 100%);
  box-shadow: 0 -18px 30px rgba(15, 23, 42, 0.08);
  backdrop-filter: blur(14px);
}

.tripbusan-business-type-strip[hidden] {
  display: none !important;
}

.tripbusan-business-type-strip > div,
.tripbusan-business-type-strip > .tripbusan-business-type-head {
  width: min(760px, 100%);
  margin: 0 auto;
}

.tripbusan-business-type-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 0 6px;
  color: #27474d;
}

.tripbusan-business-type-head strong {
  font-size: 0.82rem;
  font-weight: 900;
  letter-spacing: -0.01em;
}

.tripbusan-business-type-head a {
  color: #007d80;
  font-size: 0.75rem;
  font-weight: 800;
  text-decoration: none;
}

.tripbusan-business-type-scroll {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding: 2px 4px 2px;
  scroll-snap-type: x proximity;
  scrollbar-width: none;
}

.tripbusan-business-type-scroll::-webkit-scrollbar {
  display: none;
}

.tripbusan-business-type-chip {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 46px;
  padding: 0 16px;
  border: 1px solid rgba(8, 102, 108, 0.14);
  border-radius: 16px;
  background: #fff;
  color: #1d4f55;
  text-decoration: none;
  box-shadow: 0 10px 24px rgba(11, 65, 73, 0.08);
  scroll-snap-align: start;
  white-space: nowrap;
}

.tripbusan-business-type-chip span {
  font-size: 1rem;
}

.tripbusan-business-type-chip strong {
  font-size: 0.88rem;
  font-weight: 850;
}

.tripbusan-business-type-chip.active {
  border-color: rgba(0, 125, 128, 0.24);
  background: linear-gradient(135deg, #eefdf8, #e5fbf4);
  color: #006f73;
}

.tripbusan-location-notice {
  position: fixed;
  left: 50%;
  top: 50%;
  z-index: 140;
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  align-items: stretch;
  width: min(420px, calc(100% - 32px));
  margin: 0 auto;
  padding: 22px;
  border: 1px solid rgba(42, 193, 188, 0.26);
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.97);
  box-shadow: 0 26px 70px rgba(5, 33, 38, 0.28);
  color: #16313e;
  transform: translate(-50%, -50%);
  backdrop-filter: blur(16px);
}

.tripbusan-location-notice::before {
  content: "";
  position: fixed;
  inset: -100vh -100vw;
  z-index: -1;
  background: rgba(5, 33, 38, 0.28);
  pointer-events: none;
}

.tripbusan-location-notice[hidden] {
  display: none !important;
}

.tripbusan-location-close {
  position: absolute;
  right: 14px;
  top: 14px;
  width: 34px;
  height: 34px;
  border: 0;
  border-radius: 999px;
  background: #e8fbf6;
  color: #007d80;
  font-size: 1.2rem;
  font-weight: 950;
}

.tripbusan-location-notice strong {
  display: block;
  margin: 4px 42px 8px 0;
  font-size: 1.35rem;
  line-height: 1.1;
}

.tripbusan-location-notice p {
  margin: 0;
  color: #496a70;
  font-size: 0.98rem;
  line-height: 1.45;
}

.tripbusan-location-allow {
  width: 100%;
  min-height: 52px;
  border: 0;
  border-radius: 999px;
  background: #2ac1bc;
  color: #fff;
  font-size: 1rem;
  font-weight: 950;
  box-shadow: 0 16px 34px rgba(42, 193, 188, 0.28);
}

.tripbusan-location-allow[hidden] {
  display: none !important;
}

.tripbusan-location-notice[data-kind="success"] {
  top: auto;
  bottom: calc(78px + env(safe-area-inset-bottom));
  transform: translateX(-50%);
  grid-template-columns: 34px 1fr;
  width: min(520px, calc(100% - 24px));
  padding: 12px 14px 12px 10px;
  border-radius: 18px;
  border-color: rgba(32, 164, 113, 0.3);
}

.tripbusan-location-notice[data-kind="success"]::before {
  display: none;
}

.tripbusan-location-notice[data-kind="success"] .tripbusan-location-close {
  position: static;
}

.tripbusan-location-notice[data-kind="success"] strong {
  margin: 0 0 2px;
  font-size: 0.92rem;
}

.tripbusan-location-notice[data-kind="success"] p {
  font-size: 0.82rem;
  line-height: 1.35;
}

.tripbusan-location-notice[data-kind="requesting"] .tripbusan-location-close {
  display: none;
}

.tripbusan-location-notice[data-kind="warning"] {
  border-color: rgba(255, 169, 77, 0.38);
}

.tripbusan-install-prompt {
  position: fixed;
  left: 14px;
  right: 14px;
  bottom: calc(96px + env(safe-area-inset-bottom));
  z-index: 180;
  display: grid;
  gap: 10px;
  padding: 14px;
  border: 1px solid rgba(17, 99, 108, 0.16);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.97);
  box-shadow: 0 20px 50px rgba(5, 33, 38, 0.18);
  backdrop-filter: blur(14px);
}

.tripbusan-install-prompt[hidden] {
  display: none !important;
}

.tripbusan-install-close {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 30px;
  height: 30px;
  border: 0;
  border-radius: 999px;
  background: #e8fbf6;
  color: #007d80;
  font-size: 1rem;
  font-weight: 900;
}

.tripbusan-install-copy strong {
  display: block;
  margin-right: 34px;
  color: #0f3140;
  font-size: 1rem;
  line-height: 1.2;
}

.tripbusan-install-copy p {
  margin: 6px 34px 0 0;
  color: #53696f;
  font-size: 0.92rem;
  line-height: 1.45;
}

.tripbusan-install-actions {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
}

.tripbusan-install-primary,
.tripbusan-install-secondary,
.tripbusan-install-help-done {
  min-height: 46px;
  border: 0;
  border-radius: 999px;
  font-weight: 950;
  touch-action: manipulation;
}

.tripbusan-install-primary {
  color: #fff;
  background: linear-gradient(135deg, #0b5961, #2ac1bc);
  box-shadow: 0 14px 28px rgba(11, 89, 97, 0.24);
}

.tripbusan-install-secondary {
  padding: 0 14px;
  color: #0b5961;
  background: #edf8f7;
}

.tripbusan-install-help-modal[hidden] {
  display: none !important;
}

.tripbusan-install-help-modal {
  position: fixed;
  inset: 0;
  z-index: 6002;
  display: grid;
  place-items: end center;
  padding: 14px;
}

.tripbusan-install-help-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(5, 28, 36, 0.72);
  backdrop-filter: blur(8px);
}

.tripbusan-install-help-dialog {
  position: relative;
  z-index: 1;
  width: min(680px, 100%);
  max-height: min(82vh, 720px);
  overflow: auto;
  padding: 22px 18px 18px;
  border: 1px solid rgba(17, 99, 108, 0.18);
  border-radius: 26px;
  background:
    radial-gradient(circle at 20% 0%, rgba(32, 163, 158, 0.12), transparent 32%),
    #f8fbfa;
  box-shadow: 0 28px 90px rgba(5, 28, 36, 0.34);
}

.tripbusan-install-help-dialog h2 {
  margin: 8px 42px 12px 0;
  color: #102f3a;
  font-size: clamp(1.6rem, 6vw, 2.35rem);
  line-height: 1;
  letter-spacing: -0.06em;
}

.tripbusan-install-help-body,
.tripbusan-install-help-note p {
  color: #4d686f;
  line-height: 1.5;
}

.tripbusan-install-help-note {
  margin-top: 12px;
  padding: 14px;
  border: 1px solid rgba(17, 99, 108, 0.12);
  border-radius: 18px;
  background: #fff;
}

.tripbusan-install-help-note strong {
  display: block;
  margin-bottom: 4px;
  color: #0b5961;
}

.tripbusan-install-help-actions {
  margin-top: 16px;
}

.tripbusan-install-help-done {
  width: 100%;
  color: #fff;
  background: linear-gradient(135deg, #0b5961, #2ac1bc);
}

.tripbusan-trip-period-prompt {
  position: fixed;
  right: 14px;
  bottom: calc(96px + env(safe-area-inset-bottom));
  z-index: 130;
}

.tripbusan-trip-period-fab {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 48px;
  padding: 0 16px 0 12px;
  border: 1px solid rgba(17, 99, 108, 0.16);
  border-radius: 999px;
  color: #08333b;
  background: linear-gradient(135deg, #ffffff, #e8fbf6);
  box-shadow: 0 16px 32px rgba(5, 33, 38, 0.16);
  font-size: 0.92rem;
  font-weight: 950;
}

.tripbusan-trip-period-fab span {
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border-radius: 999px;
  color: #0b7078;
  background: #fff;
  font-size: 1rem;
  box-shadow: inset 0 0 0 1px rgba(17, 99, 108, 0.08);
}

.tripbusan-trip-period-modal[hidden] {
  display: none !important;
}

.tripbusan-trip-period-modal {
  position: fixed;
  inset: 0;
  z-index: 6001;
  display: grid;
  place-items: end center;
  padding: 14px;
}

.tripbusan-trip-period-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(5, 28, 36, 0.7);
  backdrop-filter: blur(8px);
}

.tripbusan-trip-period-dialog {
  position: relative;
  z-index: 1;
  width: min(720px, 100%);
  max-height: min(82vh, 740px);
  overflow: auto;
  padding: 22px 18px 18px;
  border: 1px solid rgba(17, 99, 108, 0.18);
  border-radius: 28px;
  background:
    radial-gradient(circle at 20% 0%, rgba(32, 163, 158, 0.12), transparent 32%),
    #f8fbfa;
  box-shadow: 0 28px 90px rgba(5, 28, 36, 0.34);
}

.tripbusan-trip-period-dialog h2 {
  margin: 8px 42px 12px 0;
  color: #102f3a;
  font-size: clamp(1.7rem, 6vw, 2.5rem);
  line-height: 1;
  letter-spacing: -0.06em;
}

.tripbusan-trip-period-body {
  margin: 0 0 16px;
  color: #47666c;
  line-height: 1.5;
}

.tripbusan-trip-period-close {
  position: absolute;
  top: 14px;
  right: 14px;
  width: 40px;
  height: 40px;
  border: 1px solid rgba(17, 99, 108, 0.18);
  border-radius: 999px;
  color: #10333d;
  background: #fff;
  font-size: 1.45rem;
  font-weight: 950;
  cursor: pointer;
}

.tripbusan-trip-period-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.tripbusan-trip-period-card {
  display: grid;
  gap: 6px;
  padding: 16px;
  border: 1px solid rgba(17, 99, 108, 0.14);
  border-radius: 22px;
  color: #11353f;
  text-decoration: none;
  background: #fff;
  box-shadow: 0 14px 30px rgba(5, 33, 38, 0.08);
}

.tripbusan-trip-period-card strong {
  font-size: 1rem;
  line-height: 1.2;
}

.tripbusan-trip-period-card p {
  margin: 0;
  color: #56757b;
  font-size: 0.92rem;
  line-height: 1.45;
}

.tripbusan-trip-period-card span {
  color: #007d80;
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

@media (min-width: 768px) {
  .tripbusan-trip-period-prompt {
    display: none;
  }

  .tripbusan-install-prompt {
    display: none;
  }
}

@media (max-width: 640px) {
  .tripbusan-trip-period-modal {
    padding: 12px;
  }

  .tripbusan-trip-period-dialog {
    width: 100%;
    max-height: 84vh;
    padding: 20px 16px 16px;
    border-radius: 24px;
  }

  .tripbusan-trip-period-grid {
    grid-template-columns: 1fr;
  }
}

.explore-mobile-home {
  width: min(760px, 100%);
  margin: 0 auto;
  padding: 12px 14px 96px;
}

.explore-home-block {
  margin: 12px 0;
  padding: 14px;
  border: 1px solid rgba(7, 112, 116, 0.14);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.92);
  box-shadow: 0 18px 48px rgba(5, 33, 38, 0.08);
}

.explore-home-block h1,
.explore-home-block h2 {
  margin: 4px 0 8px;
}

.explore-main-title span {
  display: block;
}

.daily-shorts-block {
  padding-bottom: 16px;
}

.daily-shorts-slider {
  display: flex;
  gap: 12px;
  overflow-x: auto;
  overscroll-behavior-x: contain;
  scroll-snap-type: x mandatory;
  padding: 4px 2px 10px;
  scrollbar-width: thin;
}

.daily-shorts-card {
  flex: 0 0 min(70vw, 230px);
  overflow: hidden;
  border: 1px solid rgba(7, 112, 116, 0.18);
  border-radius: 22px;
  background: #fff;
  box-shadow: 0 14px 34px rgba(5, 33, 38, 0.1);
  scroll-snap-align: start;
}

.daily-shorts-card iframe,
.daily-shorts-placeholder {
  display: block;
  width: 100%;
  aspect-ratio: 9 / 16;
  border: 0;
  background: linear-gradient(145deg, #0b5960, #0aa7a2);
}

.daily-shorts-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 8px;
  color: #fff;
  text-decoration: none;
  font-weight: 900;
}

.daily-shorts-card div {
  padding: 10px 12px 12px;
}

.daily-shorts-card strong {
  display: block;
  color: #0d3037;
  font-size: 0.95rem;
  line-height: 1.25;
}

.daily-shorts-card p {
  margin: 5px 0 0;
  color: #5d7479;
  font-size: 0.78rem;
  line-height: 1.35;
}

.today-coupon-grid {
  display: grid;
  grid-template-columns: 1fr;
  grid-auto-flow: row;
  grid-auto-rows: auto;
  align-items: stretch;
  gap: 10px;
}

.today-coupon-grid .daily-shorts-card {
  width: 100%;
  flex: none;
  border-radius: 14px;
  box-shadow: 0 8px 20px rgba(5, 33, 38, 0.08);
}

.today-coupon-grid .daily-shorts-placeholder {
  aspect-ratio: 16 / 9;
  min-height: 76px;
  gap: 4px;
  padding: 8px;
}

.today-coupon-grid .daily-shorts-card div {
  padding: 8px 9px 9px;
}

.today-coupon-grid .daily-shorts-card strong {
  font-size: 0.82rem;
}

.today-coupon-grid .daily-shorts-card p {
  font-size: 0.7rem;
  line-height: 1.25;
}

.large-category-grid,
.explore-icon-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.explore-icon-grid button {
  min-height: 86px;
  border: 1px solid rgba(7, 112, 116, 0.18);
  border-radius: 20px;
  background: #fff;
  color: #092f36;
  box-shadow: 0 10px 22px rgba(5, 33, 38, 0.07);
}

.explore-icon-grid button span {
  display: block;
  margin-bottom: 8px;
  font-size: 1.75rem;
}

.explore-icon-grid button strong {
  font-size: 0.9rem;
}

.explore-icon-grid button.active {
  border-color: #08a7a2;
  background: #09b7b2;
  color: #fff;
}

.explore-chip-row {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding: 2px 2px 8px;
  scrollbar-width: none;
}

.explore-chip-row::-webkit-scrollbar {
  display: none;
}

.explore-chip-row button {
  flex: 0 0 auto;
  min-height: 44px;
  padding: 0 16px;
  border-radius: 999px;
  border: 1px solid rgba(7, 112, 116, 0.18);
  background: #fff;
  color: #174148;
  font-weight: 800;
}

.explore-chip-row button.active {
  background: #007d80;
  color: #fff;
  border-color: #007d80;
}

.baemin-location-note {
  margin: 12px 0;
  border-radius: 18px;
  background: #eaf8f5;
}

.baemin-result-list {
  display: grid;
  gap: 14px;
}

.explore-list-heading {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 12px;
  padding: 6px 2px;
}

.explore-list-heading h2 {
  margin: 0;
  font-size: clamp(1.35rem, 6vw, 2.1rem);
}

.explore-list-heading p {
  margin: 4px 0 0;
  color: #5b7379;
}

.baemin-place-card {
  overflow: hidden;
  border-radius: 22px;
  border: 1px solid rgba(7, 112, 116, 0.14);
  background: #fff;
  box-shadow: 0 16px 40px rgba(5, 33, 38, 0.1);
}

.baemin-place-card .explore-list-card-link {
  position: absolute;
  inset: 0;
  display: block;
  text-decoration: none;
}

.baemin-place-card .explore-list-photo {
  position: relative;
  min-height: 210px;
  border-radius: 22px 22px 0 0;
  background-image: linear-gradient(180deg, rgba(8, 34, 40, 0.08), rgba(8, 34, 40, 0.82)), var(--hot-spot-image);
  background-size: cover;
  background-position: center;
}

.baemin-place-card .explore-list-overlay {
  position: absolute;
  left: 14px;
  right: 14px;
  bottom: 14px;
  color: #fff;
  text-shadow: 0 2px 14px rgba(0, 0, 0, 0.34);
}

.baemin-place-card .explore-list-title-row {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 8px;
}

.baemin-place-card h2 {
  margin: 0;
  max-width: 78%;
  color: #fff;
  font-size: 1.35rem;
  line-height: 1.05;
}

.baemin-place-card h2 small {
  display: block;
  margin-top: 5px;
  color: rgba(255, 255, 255, 0.9);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0;
  line-height: 1.1;
  text-transform: lowercase;
}

.baemin-place-card .explore-list-meta {
  margin: 7px 0 0;
  color: rgba(255, 255, 255, 0.92);
  font-weight: 800;
}

.baemin-place-card .explore-list-meta-row {
  margin-top: 7px;
}

.baemin-place-card .explore-list-meta-row .explore-list-meta {
  margin: 0;
  font-size: 1.08rem;
  line-height: 1.25;
}

.baemin-place-card .explore-list-meta-row .place-rating-stack {
  margin-top: 0;
  color: #ffffff;
  text-align: right;
  text-shadow: 0 2px 10px rgba(0, 0, 0, 0.34);
}

.explore-heart-button {
  position: absolute;
  right: 12px;
  top: 12px;
  z-index: 2;
  width: 42px;
  height: 42px;
  border: 0;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.9);
  color: #0b5960;
  font-size: 1.4rem;
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.18);
}

.explore-heart-button.is-saved {
  color: #ff4f73;
}

.explore-card-badge {
  position: absolute;
  left: 12px;
  top: 12px;
  z-index: 2;
  padding: 7px 10px;
  border-radius: 999px;
  background: #fff5c5;
  color: #5a4500;
  font-size: 0.74rem;
  font-weight: 900;
}

.explore-list-mini-meta {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  padding: 10px 14px 13px;
  color: #3f6268;
  font-size: 0.83rem;
  font-weight: 800;
}

.favorite-schedule-card .schedule-card-main {
  display: grid;
  grid-template-columns: 72px 1fr;
  gap: 12px;
  color: inherit;
  text-decoration: none;
}

.favorite-schedule-card img {
  width: 72px;
  height: 72px;
  border-radius: 16px;
  object-fit: cover;
}

@media (min-width: 680px) {
  .large-category-grid,
  .explore-icon-grid {
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }

  .baemin-result-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.driver-booking-card {
  border-left: 5px solid #0b7f82;
}

.driver-detail-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin: 14px 0;
}

.driver-detail-grid p {
  background: #f2f8f8;
  border: 1px solid #d9ecec;
  border-radius: 14px;
  margin: 0;
  padding: 10px 12px;
}

.driver-detail-grid small {
  color: #637982;
  display: block;
  font-weight: 700;
  letter-spacing: .02em;
  margin-bottom: 4px;
}

.driver-detail-grid strong {
  color: #102f3a;
  display: block;
  line-height: 1.35;
  overflow-wrap: anywhere;
}

.driver-status-actions {
  border-top: 1px solid #d9ecec;
  margin-top: 16px;
  padding-top: 14px;
}

.driver-status-actions .secondary-button-like {
  min-height: 42px;
}

@media (max-width: 720px) {
  .driver-detail-grid {
    grid-template-columns: 1fr;
  }

  .driver-status-actions .secondary-button-like,
  .driver-booking-card .button-row a,
  .driver-booking-card .button-row button {
    justify-content: center;
    width: 100%;
  }
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html,
body {
  max-width: 100%;
  overflow-x: hidden;
}

img,
video,
iframe {
  max-width: 100%;
}

.slider-has-arrow-bar {
  cursor: default !important;
}

.slider-arrow-bar {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 10px 0 26px;
  padding: 8px;
  border: 1px solid rgba(17, 99, 108, 0.24);
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(235, 249, 247, 0.92), rgba(255, 255, 255, 0.98));
  box-shadow: 0 14px 34px rgba(8, 55, 65, 0.1);
}

.slider-arrow-button {
  flex: 0 0 auto;
  width: 46px;
  height: 42px;
  border: 0;
  border-radius: 999px;
  color: #fff;
  background: #0b7078;
  font-size: 1.55rem;
  font-weight: 950;
  line-height: 1;
  box-shadow: 0 10px 24px rgba(10, 86, 96, 0.2);
  cursor: pointer;
}

.slider-arrow-button:disabled {
  opacity: 0.34;
  cursor: default;
  box-shadow: none;
}

.slider-arrow-track {
  position: relative;
  flex: 1 1 auto;
  min-width: 96px;
  height: 42px;
  overflow: hidden;
  border: 1px solid rgba(17, 99, 108, 0.2);
  border-radius: 999px;
  background:
    linear-gradient(90deg, rgba(17, 99, 108, 0.12), rgba(17, 99, 108, 0.04)),
    repeating-linear-gradient(90deg, transparent, transparent 16px, rgba(17, 99, 108, 0.08) 16px, rgba(17, 99, 108, 0.08) 18px);
  cursor: pointer;
}

.slider-arrow-thumb {
  position: absolute;
  inset: 7px auto 7px 7px;
  min-width: 52px;
  border-radius: 999px;
  background: linear-gradient(135deg, #0b7078, #20a39e);
  box-shadow: 0 8px 18px rgba(10, 86, 96, 0.25);
  transition: width 0.16s ease, transform 0.16s ease;
}

.slider-arrow-label {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  color: rgba(17, 55, 68, 0.7);
  font-size: 0.86rem;
  font-weight: 900;
  pointer-events: none;
}

.slider-arrow-bar[hidden] {
  display: none;
}

@media (max-width: 640px) {
  .slider-arrow-bar {
    gap: 8px;
    margin-bottom: 24px;
    padding: 7px;
  }

  .slider-arrow-button {
    width: 48px;
    height: 44px;
  }

.slider-arrow-track {
    height: 44px;
  }
}

.landing-only-page {
  background: #f7faf9;
}

.landing-only-header {
  position: fixed;
  z-index: 30;
  top: 0;
  right: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px clamp(20px, 5vw, 72px);
  color: #fff;
  background: linear-gradient(180deg, rgba(7, 35, 44, 0.72), rgba(7, 35, 44, 0));
}

.landing-brand {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  color: #fff;
  text-decoration: none;
}

.landing-brand-image img {
  display: block;
  width: 196px;
  max-width: 42vw;
  height: auto;
}

.landing-brand-mark {
  display: inline-grid;
  width: 34px;
  height: 34px;
  place-items: center;
  border-radius: 8px;
  color: #fff;
  background: rgba(8, 35, 48, 0.86);
  font-size: 0.8rem;
  font-weight: 950;
}

.landing-brand strong {
  font-size: 1.35rem;
  font-weight: 950;
  letter-spacing: -0.04em;
}

.landing-top-actions {
  position: relative;
  display: flex;
  align-items: center;
  gap: 10px;
}

.landing-language-menu {
  position: relative;
}

#language-toggle,
.landing-menu-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 44px;
  height: 40px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 999px;
  color: #fff;
  background: rgba(255, 255, 255, 0.12);
  font-weight: 950;
  backdrop-filter: blur(12px);
  cursor: pointer;
}

#language-toggle {
  gap: 6px;
  padding: 0 12px;
}

.landing-menu-toggle {
  width: 44px;
  flex-direction: column;
  gap: 5px;
}

.landing-menu-toggle span {
  display: block;
  width: 18px;
  height: 2px;
  border-radius: 999px;
  background: #fff;
}

.landing-language-dropdown,
.landing-menu-panel {
  position: absolute;
  top: calc(100% + 12px);
  right: 0;
  min-width: 210px;
  padding: 10px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 18px;
  background: rgba(7, 35, 44, 0.94);
  box-shadow: 0 18px 42px rgba(0, 0, 0, 0.24);
  backdrop-filter: blur(18px);
}

.landing-language-dropdown button,
.landing-menu-panel a {
  display: flex;
  width: 100%;
  align-items: center;
  padding: 12px 13px;
  border: 0;
  border-radius: 12px;
  color: #fff;
  background: transparent;
  font-weight: 850;
  text-align: left;
  text-decoration: none;
  cursor: pointer;
}

.landing-language-dropdown button:hover,
.landing-language-dropdown button.active,
.landing-menu-panel a:hover {
  background: rgba(255, 255, 255, 0.13);
}

.landing-menu-panel {
  right: clamp(20px, 5vw, 72px);
  min-width: min(320px, calc(100vw - 40px));
}

.tripbusan-landing-hero {
  position: relative;
  min-height: 100vh;
  overflow: hidden;
  color: #fff;
  background: #0a2b36;
}

.hero-background-video {
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0;
  transform: scale(1.02);
  transition: opacity 0.9s ease;
}

.tripbusan-landing-hero.has-video .hero-background-video {
  opacity: 1;
}

.tripbusan-landing-hero.has-video .hero-visual-slider {
  opacity: 0;
}

.hero-visual-slider {
  position: absolute;
  inset: 0;
  z-index: 0;
  transition: opacity 0.9s ease;
}

.hero-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transform: scale(1.05);
  animation: landingHeroSlide 30s infinite;
  background-size: cover;
  background-position: center;
}

.hero-slide.haeundae {
  opacity: 1;
  background:
    radial-gradient(circle at 24% 28%, rgba(255, 255, 255, 0.28), transparent 0 18%, transparent 36%),
    linear-gradient(135deg, rgba(12, 119, 132, 0.86), rgba(9, 34, 50, 0.9)),
    url("https://images.unsplash.com/photo-1601024445121-e5b82f020549?auto=format&fit=crop&w=1800&q=72");
}

.hero-slide.gwangalli {
  animation-delay: 6s;
  background:
    radial-gradient(circle at 64% 30%, rgba(255, 232, 151, 0.34), transparent 0 12%, transparent 30%),
    radial-gradient(circle at 18% 18%, rgba(93, 211, 255, 0.28), transparent 0 12%, transparent 28%),
    radial-gradient(circle at 82% 18%, rgba(255, 126, 206, 0.24), transparent 0 10%, transparent 26%),
    linear-gradient(135deg, rgba(12, 42, 79, 0.88), rgba(9, 23, 42, 0.92));
}

.hero-slide.gamcheon {
  animation-delay: 12s;
  background:
    linear-gradient(135deg, rgba(28, 84, 101, 0.9), rgba(72, 38, 91, 0.9)),
    repeating-linear-gradient(135deg, rgba(255, 181, 85, 0.22) 0 18px, rgba(255, 255, 255, 0.08) 18px 36px);
}

.hero-slide.yeonhwa {
  animation-delay: 18s;
  background:
    radial-gradient(circle at 72% 26%, rgba(255, 214, 145, 0.38), transparent 0 16%, transparent 34%),
    radial-gradient(circle at 26% 58%, rgba(75, 209, 219, 0.24), transparent 0 18%, transparent 40%),
    linear-gradient(135deg, rgba(13, 79, 91, 0.9), rgba(13, 40, 53, 0.92));
}

.hero-slide.night {
  animation-delay: 24s;
  background:
    radial-gradient(circle at 70% 26%, rgba(114, 205, 255, 0.32), transparent 0 18%, transparent 35%),
    radial-gradient(circle at 42% 38%, rgba(255, 230, 136, 0.2), transparent 0 12%, transparent 30%),
    linear-gradient(135deg, rgba(8, 28, 52, 0.92), rgba(16, 86, 91, 0.88));
}

.ai-busan-motion {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  contain: paint;
  opacity: 0.7;
}

.motion-orb,
.drone-light,
.sea-shimmer {
  position: absolute;
  will-change: transform, opacity;
}

.motion-orb {
  width: clamp(170px, 24vw, 360px);
  height: clamp(170px, 24vw, 360px);
  border-radius: 999px;
  filter: blur(34px);
  opacity: 0.32;
  background: rgba(255, 255, 255, 0.28);
  animation: busanOrbFloat 14s ease-in-out infinite alternate;
}

.orb-one {
  top: 14%;
  left: 8%;
  background: rgba(120, 220, 255, 0.28);
}

.orb-two {
  right: 9%;
  bottom: 18%;
  animation-delay: 2s;
  background: rgba(255, 205, 122, 0.28);
}

.orb-three {
  top: 28%;
  right: 28%;
  animation-delay: 4s;
  background: rgba(255, 125, 165, 0.22);
}

.drone-light {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.9);
  box-shadow: 0 0 18px rgba(255, 255, 255, 0.85);
  animation: droneDrift 9s linear infinite;
}

.d1 { top: 18%; left: 58%; }
.d2 { top: 24%; left: 64%; animation-delay: 0.8s; }
.d3 { top: 20%; left: 70%; animation-delay: 1.6s; }
.d4 { top: 30%; left: 76%; animation-delay: 2.4s; }
.d5 { top: 16%; left: 82%; animation-delay: 3.2s; }

.sea-shimmer {
  right: -8%;
  left: -8%;
  height: 1px;
  border-radius: 999px;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.42), transparent);
  animation: seaShimmer 8s ease-in-out infinite;
}

.s1 { bottom: 18%; }
.s2 { bottom: 13%; animation-delay: 1.7s; }
.s3 { bottom: 8%; animation-delay: 3.4s; }

@media (prefers-reduced-motion: reduce) {
  .hero-slide,
  .motion-orb,
  .drone-light,
  .sea-shimmer {
    animation: none !important;
  }
}

@keyframes busanOrbFloat {
  from {
    transform: translate3d(-2%, -1%, 0) scale(1);
  }
  to {
    transform: translate3d(5%, 4%, 0) scale(1.08);
  }
}

@keyframes droneDrift {
  0% {
    opacity: 0;
    transform: translate3d(-18px, 8px, 0) scale(0.75);
  }
  18%,
  72% {
    opacity: 0.88;
  }
  100% {
    opacity: 0;
    transform: translate3d(42px, -18px, 0) scale(1.05);
  }
}

@keyframes seaShimmer {
  0%,
  100% {
    opacity: 0.12;
    transform: translate3d(-4%, 0, 0);
  }
  50% {
    opacity: 0.42;
    transform: translate3d(4%, 0, 0);
  }
}

.hero-overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(3, 23, 31, 0.92), rgba(3, 23, 31, 0.58), rgba(3, 23, 31, 0.18)),
    linear-gradient(0deg, rgba(3, 23, 31, 0.72), transparent 45%);
}

.landing-hero-inner {
  position: relative;
  z-index: 2;
  display: grid;
  min-height: 100vh;
  align-content: center;
  gap: 34px;
  width: min(1120px, calc(100% - 40px));
  margin: 0 auto;
  padding: 92px 0 64px;
}

.language-switcher {
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
}

.language-switcher button {
  border: 1px solid rgba(255, 255, 255, 0.26);
  border-radius: 999px;
  padding: 10px 14px;
  color: #fff;
  background: rgba(255, 255, 255, 0.1);
  font-weight: 850;
  backdrop-filter: blur(10px);
  cursor: pointer;
}

.language-switcher button.active {
  color: #07313a;
  background: #fff;
}

.landing-hero-copy {
  max-width: 840px;
}

.landing-hero-copy-centered {
  margin: 0 auto;
  text-align: center;
}

.landing-hero-copy-centered .hero-lead {
  margin-right: auto;
  margin-left: auto;
}

.landing-hero-copy .eyebrow {
  color: #91f0e8;
}

.landing-hero-copy h1 {
  margin: 0;
  font-size: clamp(4rem, 12vw, 9rem);
  line-height: 0.9;
  letter-spacing: -0.085em;
}

.landing-hero-copy-centered h1 {
  text-shadow: 0 22px 58px rgba(0, 0, 0, 0.34);
}

.hero-lead {
  max-width: 720px;
  margin: 26px 0 0;
  color: rgba(255, 255, 255, 0.88);
  font-size: clamp(1.1rem, 2.2vw, 1.55rem);
  line-height: 1.55;
}

.hero-main-message {
  color: rgba(255, 255, 255, 0.94);
  font-weight: 850;
}

.hero-promise-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  max-width: 840px;
  margin-top: 30px;
}

.hero-promise-grid span,
.hero-promise-action {
  min-height: 82px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(255, 255, 255, 0.22);
  border-radius: 18px;
  color: #fff;
  background: rgba(255, 255, 255, 0.11);
  font-weight: 950;
  text-align: center;
  backdrop-filter: blur(12px);
}

.hero-promise-action {
  text-decoration: none;
}

.landing-scroll-button {
  display: inline-flex;
  width: fit-content;
  margin-top: 28px;
  padding: 15px 22px;
  border-radius: 999px;
  color: #07313a;
  background: #fff;
  font-weight: 950;
  text-decoration: none;
  box-shadow: 0 18px 42px rgba(0, 0, 0, 0.18);
}

.landing-how-modal[hidden] {
  display: none !important;
}

.landing-how-modal {
  position: fixed;
  inset: 0;
  z-index: 6000;
  display: grid;
  place-items: center;
  padding: 18px;
}

.landing-how-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(5, 28, 36, 0.72);
  backdrop-filter: blur(8px);
}

.landing-how-modal-dialog {
  position: relative;
  z-index: 1;
  width: min(680px, 100%);
  max-height: min(82vh, 720px);
  overflow: auto;
  padding: 26px;
  border: 1px solid rgba(17, 99, 108, 0.18);
  border-radius: 28px;
  background:
    radial-gradient(circle at 20% 0%, rgba(32, 163, 158, 0.12), transparent 32%),
    #f8fbfa;
  box-shadow: 0 28px 90px rgba(5, 28, 36, 0.34);
}

.landing-how-modal-dialog h2 {
  max-width: 540px;
  margin: 8px 42px 22px 0;
  color: #102f3a;
  font-size: clamp(2rem, 5vw, 3.25rem);
  line-height: 0.98;
  letter-spacing: -0.06em;
}

.landing-how-modal-close {
  position: absolute;
  top: 14px;
  right: 14px;
  width: 42px;
  height: 42px;
  border: 1px solid rgba(17, 99, 108, 0.18);
  border-radius: 999px;
  color: #10333d;
  background: #fff;
  font-size: 1.45rem;
  font-weight: 950;
  cursor: pointer;
}

.modal-flow-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-top: 0;
}

body.modal-open {
  overflow: hidden;
}

@media (max-width: 640px) {
  .landing-how-modal {
    align-items: end;
    padding: 12px;
  }

  .landing-how-modal-dialog {
    width: 100%;
    max-height: 82vh;
    padding: 22px 16px 18px;
    border-radius: 24px;
  }

  .landing-how-modal-dialog h2 {
    margin-right: 44px;
    margin-bottom: 18px;
    font-size: clamp(1.75rem, 9vw, 2.45rem);
  }

  .modal-flow-grid {
    grid-template-columns: 1fr;
    gap: 10px;
  }
}

.landing-intro-section,
.landing-services-section,
.landing-menu-entry-section,
.landing-explore-business-section,
.landing-premium-section,
.pay-later-section,
.landing-flow-section,
.landing-final-section {
  width: min(1120px, calc(100% - 40px));
  margin: 0 auto;
  padding: clamp(58px, 8vw, 96px) 0;
}

.tripbusan-value-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
  margin-top: 30px;
}

.tripbusan-value-grid article {
  min-height: 168px;
  padding: 24px;
  border: 1px solid rgba(17, 99, 108, 0.16);
  border-radius: 26px;
  background:
    radial-gradient(circle at 22% 12%, rgba(32, 163, 158, 0.12), transparent 28%),
    #fff;
  box-shadow: 0 18px 42px rgba(8, 55, 65, 0.08);
}

.tripbusan-value-grid strong {
  display: block;
  color: #0b7078;
  font-size: 1.25rem;
  line-height: 1.18;
}

.tripbusan-value-grid p {
  margin: 12px 0 0;
  color: #58717b;
  line-height: 1.65;
}

.landing-menu-card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  margin-top: 30px;
}

.landing-menu-card-grid.five-menu-grid {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

.landing-menu-card {
  position: relative;
  overflow: hidden;
  display: grid;
  min-height: 230px;
  align-content: end;
  gap: 12px;
  padding: 24px;
  border-radius: 28px;
  color: #fff;
  text-decoration: none;
  background:
    radial-gradient(circle at 22% 18%, rgba(255, 255, 255, 0.28), transparent 0 18%, transparent 38%),
    linear-gradient(135deg, #0b7078, #0a2b36);
  box-shadow: 0 20px 44px rgba(8, 55, 65, 0.14);
}

.landing-menu-card::after {
  content: "→";
  position: absolute;
  top: 18px;
  right: 22px;
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  color: #0a2b36;
  background: #fff;
  font-weight: 950;
}

.landing-menu-card span {
  font-size: 2.35rem;
}

.landing-menu-card strong {
  font-size: clamp(1.45rem, 3vw, 2rem);
  line-height: 1.1;
  letter-spacing: -0.045em;
}

.landing-menu-card small {
  max-width: 280px;
  color: rgba(255, 255, 255, 0.84);
  font-size: 0.98rem;
  font-weight: 800;
  line-height: 1.55;
}

.five-menu-grid .landing-menu-card {
  min-height: 250px;
}

.five-menu-grid .landing-menu-card strong {
  font-size: clamp(1.25rem, 2vw, 1.65rem);
}

.landing-explore-business-section {
  display: grid;
  gap: 22px;
  padding: clamp(34px, 6vw, 66px);
  border: 1px solid rgba(17, 99, 108, 0.16);
  border-radius: 30px;
  background:
    radial-gradient(circle at 92% 12%, rgba(15, 120, 130, 0.13), transparent 28%),
    linear-gradient(135deg, #f7fcfb, #ffffff);
  box-shadow: 0 18px 44px rgba(19, 68, 78, 0.08);
}

.explore-business-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.explore-business-grid article {
  display: grid;
  gap: 8px;
  padding: 18px;
  border: 1px solid #dce7e9;
  border-radius: 20px;
  background: #fff;
}

.explore-business-grid strong {
  color: #102f3a;
  font-size: 1.05rem;
}

.explore-business-grid p {
  margin: 0;
  color: #5f7480;
  line-height: 1.55;
}

.landing-explore-business-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.landing-premium-section {
  padding-top: 24px;
}

.landing-premium-section .section-title-row {
  margin-bottom: 18px;
}

.landing-premium-section .section-title-row h2 {
  margin: 8px 0 12px;
  font-size: clamp(2rem, 4.8vw, 4rem);
  line-height: 1.02;
  letter-spacing: -0.065em;
}

.landing-section-heading {
  max-width: 820px;
}

.landing-section-heading h2,
.pay-later-section h2,
.landing-final-section h2 {
  margin: 8px 0 14px;
  color: #122f3a;
  font-size: clamp(2.1rem, 5vw, 4.25rem);
  line-height: 1.02;
  letter-spacing: -0.065em;
}

.landing-section-heading p:not(.eyebrow),
.pay-later-section p,
.landing-final-section p {
  color: #526b76;
  font-size: 1.08rem;
  line-height: 1.75;
}

.landing-service-grid,
.landing-flow-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
  margin-top: 30px;
}

.landing-service-card,
.landing-flow-grid article,
.noshow-card {
  border: 1px solid rgba(17, 99, 108, 0.16);
  border-radius: 26px;
  background: #fff;
  box-shadow: 0 18px 42px rgba(8, 55, 65, 0.08);
}

.landing-service-card {
  min-height: 260px;
  padding: 24px;
}

.landing-service-card span,
.landing-flow-grid strong {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 42px;
  height: 42px;
  border-radius: 999px;
  color: #fff;
  background: #0b7078;
  font-weight: 950;
}

.landing-service-card h3,
.landing-flow-grid h3,
.noshow-card h3 {
  margin: 18px 0 10px;
  color: #132f3a;
  font-size: 1.45rem;
  line-height: 1.1;
  letter-spacing: -0.045em;
}

.landing-service-card p,
.landing-flow-grid p,
.noshow-card p {
  color: #59717b;
  line-height: 1.65;
}

.pay-later-section {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(280px, 0.8fr);
  gap: 28px;
  align-items: stretch;
}

.noshow-card {
  padding: 28px;
  background: linear-gradient(135deg, #fff7e4, #fff);
}

.noshow-card span {
  color: #b75b3c;
  font-size: 0.82rem;
  font-weight: 950;
  letter-spacing: 0.13em;
}

.landing-flow-grid article {
  padding: 24px;
}

.compact-landing-flow-section {
  padding-top: 0;
}

.landing-help-grid,
.traveler-like-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
  margin-top: 28px;
}

.landing-help-grid article {
  display: grid;
  gap: 14px;
  min-height: 190px;
  align-content: end;
  padding: 24px;
  border-radius: 28px;
  color: #fff;
  background:
    radial-gradient(circle at 26% 20%, rgba(255, 255, 255, 0.3), transparent 0 16%, transparent 34%),
    linear-gradient(135deg, #0c6670, #0a2836);
  box-shadow: 0 20px 42px rgba(8, 55, 65, 0.13);
}

.landing-help-grid span {
  font-size: 2.1rem;
}

.landing-help-grid strong {
  font-size: 1.35rem;
  line-height: 1.15;
}

.landing-explore-preview,
.landing-review-section {
  width: min(1120px, calc(100% - 40px));
  margin: 0 auto;
  padding: clamp(58px, 8vw, 96px) 0;
}

.area-preview-stack {
  display: grid;
  gap: 22px;
  margin-top: 28px;
}

.area-preview-stack article {
  overflow: hidden;
  padding: 24px;
  border: 1px solid rgba(17, 99, 108, 0.16);
  border-radius: 28px;
  background: #fff;
  box-shadow: 0 18px 42px rgba(8, 55, 65, 0.08);
}

.area-preview-stack h3 {
  margin: 0 0 16px;
  color: #12313b;
  font-size: clamp(1.8rem, 4vw, 3rem);
  letter-spacing: -0.065em;
}

.area-chip-row {
  display: flex;
  gap: 12px;
  overflow-x: auto;
  padding-bottom: 8px;
  scrollbar-width: thin;
}

.area-chip-row span {
  flex: 0 0 auto;
  min-width: 150px;
  padding: 18px 20px;
  border-radius: 20px;
  color: #fff;
  background:
    radial-gradient(circle at 30% 24%, rgba(255, 255, 255, 0.28), transparent 0 18%, transparent 38%),
    linear-gradient(135deg, #123945, #0a7279);
  font-weight: 950;
  box-shadow: 0 12px 26px rgba(8, 55, 65, 0.12);
}

.traveler-like-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.traveler-like-grid article {
  min-height: 210px;
  padding: 26px;
  border-radius: 28px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.9), #fff),
    radial-gradient(circle at 20% 10%, rgba(32, 163, 158, 0.18), transparent 0 22%, transparent 44%);
  border: 1px solid rgba(17, 99, 108, 0.16);
  box-shadow: 0 18px 42px rgba(8, 55, 65, 0.08);
}

.traveler-like-grid strong {
  color: #0b7078;
  font-size: 1.3rem;
}

.traveler-like-grid p {
  color: #58717b;
  line-height: 1.7;
}

.landing-final-section {
  padding-bottom: 120px;
  text-align: center;
}

.landing-final-section .eyebrow {
  justify-content: center;
}

.landing-start-booking-button {
  display: inline-flex;
  margin-top: 28px;
  padding: 17px 30px;
  border-radius: 999px;
  color: #fff;
  background: #0b7078;
  font-size: 1.08rem;
  font-weight: 950;
  text-decoration: none;
  box-shadow: 0 18px 42px rgba(8, 55, 65, 0.18);
}

@keyframes landingHeroSlide {
  0%,
  100% {
    opacity: 0;
    transform: scale(1.08);
  }
  3%,
  18% {
    opacity: 1;
    transform: scale(1);
  }
  22% {
    opacity: 0;
    transform: scale(1.03);
  }
}

@media (max-width: 900px) {
  .hero-promise-grid,
  .tripbusan-value-grid,
  .landing-menu-card-grid,
  .landing-menu-card-grid.five-menu-grid,
  .landing-service-grid,
  .landing-help-grid,
  .traveler-like-grid,
  .landing-flow-grid,
  .pay-later-section {
    grid-template-columns: 1fr;
  }

  .landing-service-card {
    min-height: 0;
  }

  .tripbusan-value-grid article,
  .landing-menu-card {
    min-height: 0;
  }
}

@media (max-width: 620px) {
  .landing-only-header {
    padding: 14px 18px;
  }

  .landing-brand strong {
    font-size: 1.18rem;
  }

  .landing-brand-mark {
    width: 32px;
    height: 32px;
  }

  .landing-language-dropdown {
    right: -54px;
  }

  .landing-menu-panel {
    right: 18px;
  }

  .landing-hero-copy h1 {
    font-size: clamp(2.55rem, 12vw, 4rem);
    line-height: 1.04;
    overflow-wrap: anywhere;
  }

  .landing-hero-inner,
  .landing-hero-copy,
  .landing-hero-copy-centered {
    width: 100%;
    min-width: 0;
  }

  .hero-promise-grid {
    grid-template-columns: 1fr;
  }

  .hero-promise-grid span,
  .hero-promise-action {
    min-height: 0;
    padding: 11px 12px;
  }

  .landing-menu-card-grid {
    gap: 12px;
  }

  .landing-menu-card {
    min-height: 190px;
    padding: 20px;
  }

  .tripbusan-value-grid article {
    padding: 18px;
  }

  .landing-section-heading h2,
  .pay-later-section h2,
  .landing-final-section h2 {
    font-size: clamp(1.9rem, 10vw, 3rem);
  }

  .landing-section-heading p:not(.eyebrow),
  .pay-later-section p,
  .landing-final-section p {
    font-size: 0.98rem;
    line-height: 1.6;
  }
}

[hidden] {
  display: none !important;
}

.explore-menu-section ~ .explore-menu-section,
.reservation-request-section ~ .reservation-request-section {
  display: none !important;
}

.voucher-main {
  width: min(1120px, calc(100% - 32px));
  margin: 0 auto;
  padding: 56px 0;
}

.voucher-body {
  background: #eef2f8;
}

.voucher-soitaxi {
  width: min(680px, calc(100% - 24px));
  padding: 18px 0 28px;
}

.voucher-top-card,
.voucher-info-card,
.voucher-driver-card {
  background: linear-gradient(135deg, #2878f2 0%, #0fb879 100%);
  border-radius: 22px;
  box-shadow: 0 18px 44px rgba(8, 45, 64, 0.13);
  color: #fff;
  margin: 0 0 14px;
  padding: 18px;
  position: relative;
}

.voucher-top-header,
.voucher-driver-title {
  align-items: center;
  display: flex;
  gap: 12px;
  justify-content: space-between;
}

.voucher-system-pill,
.voucher-time-badge {
  background: rgba(255, 255, 255, 0.18);
  border-radius: 999px;
  color: #fff;
  display: inline-flex;
  font-size: 0.74rem;
  font-weight: 900;
  letter-spacing: 0.04em;
  padding: 7px 12px;
  text-transform: uppercase;
}

.voucher-guide-link {
  background: transparent;
  border: 0;
  color: #fff;
  cursor: pointer;
  font-weight: 900;
}

.voucher-top-card h1 {
  font-size: clamp(1.8rem, 8vw, 3rem);
  letter-spacing: -0.06em;
  line-height: 1;
  margin: 18px 0 8px;
}

.voucher-code {
  color: #fff;
  font-size: 1.05rem;
  font-weight: 900;
  margin: 0 0 18px;
}

.voucher-key-list {
  display: grid;
  gap: 10px;
  margin: 0;
}

.voucher-key-list div {
  align-items: start;
  display: grid;
  gap: 10px;
  grid-template-columns: 124px minmax(0, 1fr);
}

.voucher-key-list dt {
  color: rgba(255, 255, 255, 0.92);
  display: inline-flex;
  font-weight: 900;
  gap: 8px;
}

.voucher-key-list dd {
  color: #fff;
  font-weight: 900;
  margin: 0;
  overflow-wrap: anywhere;
}

.voucher-pay-pill {
  background: rgba(255, 238, 80, 0.18);
  border-radius: 999px;
  color: #fff84f;
  display: inline-flex;
  font-weight: 1000;
  margin: 18px 0 0;
  padding: 8px 12px;
}

.voucher-info-card {
  padding: 14px;
}

.voucher-info-card h2 {
  color: #fff;
  margin: 14px 0 8px;
}

.voucher-info-card ul {
  background: #fff;
  border-radius: 18px;
  color: var(--ink);
  margin: 10px 0;
  padding: 16px 18px 16px 34px;
}

.voucher-info-card li + li {
  margin-top: 8px;
}

.voucher-info-actions {
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.voucher-info-actions .primary-cta,
.voucher-info-actions .secondary-button-like {
  justify-content: center;
  min-height: 44px;
  text-align: center;
}

.voucher-driver-title {
  justify-content: flex-start;
}

.voucher-driver-icon {
  align-items: center;
  background: rgba(255, 255, 255, 0.16);
  border-radius: 14px;
  display: inline-flex;
  flex: 0 0 48px;
  height: 48px;
  justify-content: center;
  width: 48px;
}

.voucher-driver-title h2 {
  color: #fff;
  margin: 0 0 4px;
}

.voucher-driver-title p {
  color: rgba(255, 255, 255, 0.92);
  font-weight: 800;
  margin: 0;
}

.voucher-driver-list {
  border-top: 1px solid rgba(255, 255, 255, 0.28);
  display: grid;
  gap: 8px;
  margin: 16px 0;
  padding-top: 14px;
}

.voucher-driver-list div {
  display: grid;
  gap: 10px;
  grid-template-columns: 120px minmax(0, 1fr);
}

.voucher-driver-list span {
  color: rgba(255, 255, 255, 0.85);
  font-weight: 900;
}

.voucher-driver-list strong {
  color: #fff;
}

.voucher-route-box,
.flight-time-notice {
  background: rgba(255, 255, 255, 0.12);
  border-radius: 16px;
  margin-top: 14px;
  padding: 14px;
}

.voucher-route-box ol {
  margin: 8px 0 0;
  padding-left: 20px;
}

.flight-time-notice strong,
.flight-time-notice small,
.flight-time-notice p {
  color: #fff;
}

.voucher-chat-list {
  background: #f2f5fb;
  border-radius: 18px;
  max-height: 520px;
  min-height: 220px;
  overflow-y: auto;
  padding: 14px;
}

.voucher-chat-list .chat-message-card {
  background: #fff;
  border: 0;
  border-radius: 16px;
  color: var(--ink);
  margin: 0 0 10px;
  max-width: 78%;
  padding: 12px 14px;
}

.voucher-chat-list .sender-customer {
  background: #1267ff;
  color: #fff;
  margin-left: auto;
}

.voucher-chat-list .sender-driver,
.voucher-chat-list .sender-admin,
.voucher-chat-list .sender-system {
  margin-right: auto;
}

.voucher-chat-list .chat-message-card span,
.voucher-chat-list .chat-message-card small {
  color: inherit;
  opacity: 0.7;
}

.voucher-chat-list .chat-message-card p {
  margin: 6px 0 0;
}

.voucher-soitaxi .voucher-visible-actions,
.voucher-soitaxi .voucher-quick-phrases {
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.voucher-soitaxi .voucher-quick-phrases {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.voucher-hero,
.voucher-alert-card {
  border: 1px solid var(--line);
  border-radius: 22px;
  padding: clamp(24px, 4vw, 44px);
  margin-bottom: 18px;
  background: linear-gradient(135deg, rgba(232, 247, 246, 0.95), rgba(255, 255, 255, 0.96));
}

.voucher-hero h1 {
  font-size: clamp(34px, 7vw, 76px);
  line-height: 0.98;
  margin: 8px 0 16px;
}

.voucher-status-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
  margin-top: 20px;
}

.voucher-status-row strong,
.voucher-status-row span {
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 10px 14px;
  background: #fff;
}

.voucher-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  margin: 18px 0;
}

.voucher-detail-list {
  display: grid;
  gap: 10px;
  margin: 16px 0;
}

.voucher-detail-list div {
  display: grid;
  grid-template-columns: 120px minmax(0, 1fr);
  gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid rgba(15, 55, 64, 0.09);
}

.voucher-detail-list dt {
  color: var(--muted);
  font-weight: 800;
}

.voucher-detail-list dd {
  margin: 0;
  font-weight: 900;
}

.voucher-route-list {
  padding-left: 22px;
}

.voucher-route-list li {
  margin: 8px 0;
}

.voucher-waiting {
  border: 1px dashed var(--line);
  border-radius: 18px;
  padding: 18px;
  background: rgba(232, 247, 246, 0.55);
}

.voucher-vehicle-photo {
  border-radius: 18px;
  display: block;
  margin: 0 0 16px;
  max-height: 260px;
  object-fit: cover;
  width: 100%;
}

.voucher-chat-form {
  display: grid;
  gap: 12px;
}

.voucher-chat-form select,
.voucher-chat-form textarea {
  width: 100%;
}

.voucher-chat-panel {
  position: relative;
}

.voucher-guide-card {
  background: #fff8df;
  border: 1px solid rgba(230, 180, 64, 0.35);
  border-radius: 18px;
  color: var(--ink);
  margin: 16px 0;
  padding: 16px 18px;
}

.voucher-guide-card ul {
  margin: 10px 0 0;
  padding-left: 20px;
}

.voucher-guide-card li + li {
  margin-top: 6px;
}

.voucher-visible-actions,
.voucher-quick-phrases {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 14px 0;
}

.voucher-visible-actions .danger {
  border-color: rgba(220, 55, 55, 0.35);
  color: #b42318;
}

.voucher-photo-button {
  cursor: pointer;
  display: inline-flex;
  position: relative;
}

.voucher-photo-button input {
  height: 1px;
  opacity: 0;
  overflow: hidden;
  position: absolute;
  width: 1px;
}

.voucher-quick-phrases button {
  background: #f3fbfa;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--teal-800);
  cursor: pointer;
  font-weight: 800;
  padding: 10px 14px;
}

.voucher-quick-phrases button:hover {
  background: #e4f5f3;
}

.chat-image-preview {
  border-radius: 14px;
  display: block;
  margin: 8px 0;
  max-height: 220px;
  max-width: 100%;
  object-fit: cover;
}

@media (max-width: 760px) {
  .voucher-main {
    width: 100%;
    padding: 0 12px 28px;
  }

  .voucher-hero,
  .voucher-alert-card,
  .voucher-chat-panel,
  .voucher-grid > .inquiry-card,
  .voucher-grid > section,
  .voucher-grid > article {
    border-radius: 18px;
    margin-bottom: 12px;
    padding: 18px 14px;
  }

  .voucher-hero {
    margin-top: 10px;
  }

  .voucher-hero h1 {
    font-size: clamp(28px, 10vw, 42px);
    letter-spacing: -0.05em;
  }

  .voucher-status-row {
    display: grid;
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .voucher-status-row strong,
  .voucher-status-row span,
  .voucher-status-row button {
    width: 100%;
    justify-content: center;
    text-align: center;
  }

  .voucher-grid {
    grid-template-columns: 1fr;
    gap: 12px;
    margin: 12px 0;
  }

  .voucher-detail-list div {
    grid-template-columns: 88px minmax(0, 1fr);
    gap: 8px;
    padding: 8px 0;
  }

  .voucher-detail-list dt,
  .voucher-detail-list dd {
    font-size: 0.92rem;
  }

  .voucher-detail-list dd {
    overflow-wrap: anywhere;
    text-align: right;
  }

  .voucher-route-list {
    margin: 10px 0 0;
    padding-left: 18px;
  }

  .voucher-vehicle-photo {
    max-height: 190px;
    border-radius: 14px;
  }

  .voucher-visible-actions,
  .voucher-quick-phrases {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
  }

  .voucher-visible-actions .secondary-button-like,
  .voucher-quick-phrases button {
    min-height: 44px;
    padding: 10px;
    font-size: 0.9rem;
  }

  .voucher-chat-form {
    gap: 8px;
  }

  .voucher-chat-form textarea {
    min-height: 92px;
    font-size: 16px;
  }

  .voucher-chat-form .button-row,
  .voucher-alert-card .sns-next-actions {
    display: grid;
    grid-template-columns: 1fr;
  }

  .voucher-guide-card {
    margin: 12px 0;
    padding: 13px;
    border-radius: 14px;
    font-size: 0.92rem;
  }

  .chat-message-list {
    max-height: 430px;
    overflow-y: auto;
  }
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
}

.site-footer {
  margin-top: 72px;
  padding: 32px clamp(18px, 4vw, 48px);
  border-top: 1px solid #d6e6e8;
  background: #eef8f7;
}

.site-footer-inner {
  max-width: 1180px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  gap: 24px;
  align-items: center;
}

.site-footer strong {
  display: block;
  margin-bottom: 8px;
  color: #0b5f66;
  font-size: 1.15rem;
}

.site-footer p {
  margin: 0;
  max-width: 620px;
  color: #526b74;
  line-height: 1.6;
}

.site-footer nav {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-end;
}

.site-footer a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0 16px;
  border: 1px solid #bdd6da;
  border-radius: 999px;
  color: #12313d;
  background: #fff;
  font-weight: 800;
  text-decoration: none;
}

.site-footer a:first-child {
  color: #fff;
  background: #0b6f76;
  border-color: #0b6f76;
}

a {
  color: inherit;
}

button,
input,
select,
textarea {
  font: inherit;
}

.site-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 20px;
  border-bottom: 1px solid #e5ecee;
  background: #fff;
}

.logo {
  color: #105a63;
  font-size: 1.35rem;
  font-weight: 800;
  letter-spacing: -0.07em;
  text-decoration: none;
}

.header-link {
  color: #42666d;
  font-size: 0.85rem;
  text-decoration: none;
}

nav {
  display: flex;
  gap: 14px;
}

nav a {
  color: #5f727b;
  font-size: 0.83rem;
  text-decoration: none;
}

main {
  max-width: 1080px;
  margin: 0 auto;
  padding: 0 18px 110px;
}

.hero {
  display: grid;
  gap: 20px;
  padding: 56px 0 32px;
}

.eyebrow {
  margin: 0;
  color: #3f8587;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.14em;
}

h1,
h2 {
  letter-spacing: -0.045em;
}

h1 {
  max-width: 720px;
  margin: 12px 0;
  font-size: clamp(2.25rem, 9vw, 4.7rem);
  line-height: 1.04;
}

h2 {
  margin: 9px 0 14px;
  font-size: 1.75rem;
}

.summary,
.rich-copy,
.content-section > p,
.booking-help p {
  color: #647780;
  line-height: 1.7;
}

.summary {
  max-width: 680px;
  font-size: 1.05rem;
}

.hero-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 22px;
}

.hero-meta span {
  padding: 7px 10px;
  border-radius: 999px;
  color: #31666c;
  font-size: 0.8rem;
  background: #e9f5f4;
}

.booking-card {
  display: grid;
  gap: 7px;
  align-self: start;
  padding: 20px;
  border: 1px solid #dce7e9;
  border-radius: 16px;
  background: #fff;
  box-shadow: 0 12px 30px rgba(20, 72, 82, 0.07);
}

.booking-card p,
.booking-card span {
  margin: 0;
  color: #70818a;
  font-size: 0.82rem;
}

.booking-card strong {
  font-size: 1.8rem;
}

.primary-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: 12px;
  padding: 13px 16px;
  border-radius: 10px;
  color: #fff;
  font-weight: 800;
  text-decoration: none;
  background: #11636c;
}

.accent-cta {
  background: #e06b2d;
}

.content-section {
  padding: 34px 0;
  border-top: 1px solid #e4ebed;
}

.soft-section {
  padding-right: 18px;
  padding-left: 18px;
  border: 0;
  border-radius: 18px;
  background: #eff7f6;
}

.itinerary {
  display: grid;
  gap: 13px;
  margin: 20px 0 0;
  padding: 0;
  list-style: none;
}

.itinerary li {
  display: grid;
  grid-template-columns: 38px minmax(0, 1fr);
  align-items: center;
  gap: 12px;
}

.itinerary span {
  display: grid;
  width: 36px;
  height: 36px;
  place-items: center;
  border-radius: 50%;
  color: #fff;
  font-size: 0.75rem;
  font-weight: 800;
  background: #3f8587;
}

.itinerary p {
  margin: 0;
}

.link-section {
  display: grid;
  gap: 20px;
}

.link-section div {
  padding: 18px;
  border: 1px solid #e0e8ea;
  border-radius: 14px;
  background: #fff;
}

.link-section h2 {
  font-size: 1.25rem;
}

.link-section p:last-child {
  margin-bottom: 0;
  color: #6e8088;
  line-height: 1.6;
}

.faq-list {
  display: grid;
  gap: 10px;
}

details {
  padding: 15px;
  border: 1px solid #e0e8ea;
  border-radius: 10px;
  background: #fff;
}

summary {
  cursor: pointer;
  font-weight: 800;
}

details p {
  margin-bottom: 0;
  color: #667a82;
  line-height: 1.6;
}

.booking-help {
  padding: 30px;
  border-radius: 18px;
  color: #fff;
  background: #164d56;
}

.booking-help .eyebrow,
.booking-help p {
  color: #b6d5d3;
}

.mobile-cta {
  position: fixed;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 3;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 12px 18px;
  border-top: 1px solid #dce7e9;
  background: rgba(255, 255, 255, 0.96);
}

.mobile-cta div {
  display: grid;
}

.mobile-cta span {
  color: #70818a;
  font-size: 0.72rem;
}

.mobile-cta .primary-cta {
  margin: 0;
}

.inquiry-main {
  max-width: 780px;
}

.inquiry-intro {
  padding: 54px 0 20px;
}

.inquiry-intro h1 {
  font-size: clamp(2.2rem, 8vw, 4rem);
}

.inquiry-intro p:last-child {
  color: #647780;
  line-height: 1.7;
}

.inquiry-card,
.inquiry-complete {
  padding: 22px;
  border: 1px solid #dce7e9;
  border-radius: 16px;
  background: #fff;
}

.selected-tour {
  display: grid;
  gap: 5px;
  margin-bottom: 22px;
  padding-bottom: 18px;
  border-bottom: 1px solid #e5ecee;
}

.selected-tour span,
.selected-tour small {
  color: #70818a;
  font-size: 0.82rem;
}

.quick-plan-card {
  display: grid;
  gap: 14px;
  margin-bottom: 18px;
  padding: 22px;
  border: 1px solid #dce7e9;
  border-radius: 16px;
  background: #eff7f6;
}

.quick-plan-card h2 {
  margin-bottom: 0;
  font-size: 1.35rem;
}

.quick-plan-grid {
  display: grid;
  gap: 10px;
}

.quick-plan-grid button {
  cursor: pointer;
  display: grid;
  gap: 5px;
  padding: 14px;
  border: 1px solid #c7dcdf;
  border-radius: 12px;
  color: #173640;
  font-weight: 800;
  text-align: left;
  background: #fff;
}

.quick-plan-grid span {
  color: #647780;
  font-size: 0.8rem;
  font-weight: 400;
}

.private-builder-main {
  max-width: 960px;
}

.private-builder-hero h1 {
  max-width: 860px;
}

.section-title-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}

.helper-pill {
  flex: 0 0 auto;
  padding: 6px 10px;
  border-radius: 999px;
  color: #17643b;
  font-size: 0.75rem;
  font-weight: 800;
  background: #e5f6eb;
}

.slider-controls {
  display: flex;
  gap: 8px;
}

.slider-controls button {
  cursor: pointer;
  display: grid;
  width: 38px;
  height: 38px;
  place-items: center;
  border: 1px solid #c7dcdf;
  border-radius: 50%;
  color: #164d56;
  font-size: 1.5rem;
  font-weight: 800;
  background: #fff;
}

.slider-help {
  margin: -4px 0 0;
  color: #647780;
  font-size: 0.86rem;
  line-height: 1.6;
}

.course-slider-shell {
  position: relative;
  overflow: hidden;
  margin-right: -22px;
  margin-left: -22px;
  padding-left: 22px;
}

.recommended-course-slider {
  -ms-overflow-style: none;
  overscroll-behavior-inline: contain;
  user-select: none;
  touch-action: pan-y pinch-zoom;
  display: flex;
  gap: 14px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  padding: 4px 22px 18px 0;
  cursor: grab;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
}

.recommended-course-slider::-webkit-scrollbar {
  display: none;
}

.recommended-course-slider.dragging {
  cursor: grabbing;
  scroll-behavior: auto;
  scroll-snap-type: none;
}

.recommended-course-slider.dragging .recommended-course-card {
  pointer-events: none;
}

.recommended-course-card {
  cursor: pointer;
  position: relative;
  overflow: hidden;
  flex: 0 0 245px;
  display: grid;
  align-content: end;
  min-height: 310px;
  gap: 9px;
  scroll-snap-align: start;
  padding: 18px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 18px;
  color: #fff;
  text-align: left;
  background: #164d56;
  box-shadow: 0 14px 28px rgba(20, 72, 82, 0.14);
  -webkit-user-drag: none;
  user-select: none;
}

.recommended-course-card::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background:
    linear-gradient(180deg, rgba(0, 0, 0, 0.04), rgba(0, 0, 0, 0.76)),
    radial-gradient(circle at 25% 20%, rgba(255, 255, 255, 0.26), transparent 28%),
    linear-gradient(135deg, #12636b, #0f2f42);
}

.recommended-course-card::after {
  content: "Private Tour";
  position: absolute;
  top: 14px;
  left: 14px;
  z-index: 1;
  padding: 5px 8px;
  border-radius: 999px;
  color: rgba(255, 255, 255, 0.92);
  font-size: 0.66rem;
  font-weight: 800;
  background: rgba(0, 0, 0, 0.28);
  backdrop-filter: blur(6px);
}

.recommended-course-card.haeundae-gijang::before {
  background:
    linear-gradient(180deg, rgba(0, 0, 0, 0.04), rgba(0, 0, 0, 0.78)),
    radial-gradient(circle at 70% 18%, rgba(255, 214, 145, 0.8), transparent 24%),
    linear-gradient(135deg, #1c8790, #143a4b 52%, #d46b2d);
}

.recommended-course-card.busan-highlight::before {
  background:
    linear-gradient(180deg, rgba(0, 0, 0, 0.03), rgba(0, 0, 0, 0.76)),
    radial-gradient(circle at 20% 18%, rgba(179, 228, 255, 0.72), transparent 28%),
    linear-gradient(135deg, #1c6f91, #17445d 48%, #70b9b2);
}

.recommended-course-card.gamcheon-gwangalli::before {
  background:
    linear-gradient(180deg, rgba(0, 0, 0, 0.02), rgba(0, 0, 0, 0.78)),
    radial-gradient(circle at 26% 24%, rgba(255, 221, 99, 0.75), transparent 22%),
    linear-gradient(135deg, #d1584a, #624a91 50%, #164d8f);
}

.recommended-course-card.night-view::before {
  background:
    linear-gradient(180deg, rgba(0, 0, 0, 0.04), rgba(0, 0, 0, 0.82)),
    radial-gradient(circle at 78% 18%, rgba(255, 239, 165, 0.72), transparent 20%),
    linear-gradient(135deg, #081c33, #23326d 54%, #9b4b8f);
}

.recommended-course-card.airport-haeundae::before {
  background:
    linear-gradient(180deg, rgba(0, 0, 0, 0.03), rgba(0, 0, 0, 0.76)),
    radial-gradient(circle at 80% 20%, rgba(255, 255, 255, 0.78), transparent 18%),
    linear-gradient(135deg, #5c7180, #12636b 55%, #e0a247);
}

.recommended-course-card.family-easy::before {
  background:
    linear-gradient(180deg, rgba(0, 0, 0, 0.02), rgba(0, 0, 0, 0.74)),
    radial-gradient(circle at 20% 20%, rgba(255, 240, 179, 0.8), transparent 25%),
    linear-gradient(135deg, #4c9b7f, #2b6975 52%, #d89159);
}

.recommended-course-card > * {
  position: relative;
  z-index: 1;
}

.recommended-course-card span {
  color: rgba(255, 255, 255, 0.76);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.08em;
}

.recommended-course-card strong {
  font-size: 1.23rem;
  line-height: 1.25;
}

.recommended-course-card small {
  color: rgba(255, 255, 255, 0.82);
  line-height: 1.45;
}

.recommended-course-card.active {
  border-color: #fff;
  outline: 3px solid #3f8587;
  transform: translateY(-2px);
}

.favorite-route-section {
  margin-top: 18px;
}

.favorite-place-card {
  cursor: pointer;
  position: relative;
  overflow: hidden;
  flex: 0 0 240px;
  display: grid;
  align-content: end;
  min-height: 260px;
  gap: 8px;
  scroll-snap-align: start;
  padding: 16px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 18px;
  color: #fff;
  text-align: left;
  background: #123e47;
  box-shadow: 0 14px 28px rgba(20, 72, 82, 0.14);
  -webkit-user-drag: none;
  user-select: none;
}

.favorite-place-art {
  position: absolute;
  inset: 0;
  z-index: 0;
  background:
    linear-gradient(180deg, rgba(0, 0, 0, 0.05), rgba(0, 0, 0, 0.78)),
    var(--favorite-image, radial-gradient(circle at 28% 18%, rgba(255, 255, 255, 0.28), transparent 26%)),
    linear-gradient(135deg, #12636b, #0f2f42);
  background-position: center;
  background-size: cover;
}

.favorite-place-card > *:not(.favorite-place-art) {
  position: relative;
  z-index: 1;
}

.favorite-place-card span {
  color: rgba(255, 255, 255, 0.78);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.favorite-place-card strong {
  color: #fff;
  font-size: 1.18rem;
  line-height: 1.15;
}

.favorite-place-card small {
  display: -webkit-box;
  overflow: hidden;
  color: rgba(255, 255, 255, 0.82);
  font-size: 0.82rem;
  line-height: 1.45;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.favorite-place-card em {
  width: fit-content;
  margin-top: 4px;
  padding: 7px 10px;
  border-radius: 999px;
  color: #fff;
  font-style: normal;
  font-weight: 900;
  background: rgba(224, 107, 45, 0.92);
}

.favorite-place-card.active {
  outline: 4px solid rgba(224, 107, 45, 0.38);
}

.premium-place-slider {
  display: flex;
  gap: 16px;
  overflow-x: auto;
  padding: 4px 0 18px;
  cursor: grab;
  scroll-snap-type: x proximity;
  -webkit-overflow-scrolling: touch;
}

.premium-place-slider::-webkit-scrollbar {
  display: none;
}

.premium-place-card {
  position: relative;
  flex: 0 0 min(310px, 82vw);
  min-height: 340px;
  overflow: hidden;
  display: grid;
  align-content: end;
  gap: 7px;
  padding: 18px;
  border-radius: 18px;
  color: #fff;
  text-decoration: none;
  scroll-snap-align: start;
  background:
    radial-gradient(circle at 24% 18%, rgba(255, 255, 255, 0.25), transparent 26%),
    linear-gradient(145deg, #164f58, #102532 70%, #180f22);
  box-shadow: 0 16px 34px rgba(18, 63, 72, 0.16);
}

.premium-place-art {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(10, 28, 35, 0.05), rgba(10, 28, 35, 0.92)),
    var(--place-image, radial-gradient(circle at 28% 22%, rgba(255, 255, 255, 0.32), transparent 28%));
  background-size: cover;
  background-position: center;
}

.premium-place-card > *:not(.premium-place-art) {
  position: relative;
  z-index: 1;
}

.premium-place-card span {
  width: fit-content;
  padding: 6px 9px;
  border-radius: 999px;
  color: #fff;
  font-size: 0.72rem;
  font-weight: 900;
  background: rgba(9, 31, 38, 0.58);
}

.premium-place-card strong {
  font-size: 1.45rem;
  line-height: 1.08;
}

.premium-place-card small {
  color: rgba(255, 255, 255, 0.82);
  font-weight: 800;
}

.selected-course-preview {
  padding: 18px;
  border-radius: 14px;
  color: #fff;
  background: #164d56;
}

.selected-course-preview .eyebrow,
.selected-course-preview p {
  color: #b6d5d3;
}

.selected-course-preview h3,
.selected-course-preview p {
  margin: 6px 0 0;
}

.form-step-title {
  margin-bottom: 18px;
}

.memory-note {
  margin: -6px 0 0;
  padding: 10px 12px;
  border-radius: 10px;
  color: #4f6870;
  font-size: 0.82rem;
  line-height: 1.5;
  background: #f1f7f7;
}

.minimal-form-note,
.vehicle-later-note {
  margin: 0 0 18px;
  padding: 12px 14px;
  border-radius: 12px;
  color: #4f6870;
  font-size: 0.86rem;
  line-height: 1.6;
  background: #f7faf9;
}

.vehicle-later-note {
  margin-top: 16px;
  color: #6c5a34;
  background: #fff7e8;
}

.dropoff-quick {
  display: grid;
  gap: 9px;
  padding: 13px;
  border: 1px solid #dbe8ea;
  border-radius: 12px;
  background: #fff;
}

.dropoff-quick > span {
  color: #304e58;
  font-size: 0.86rem;
  font-weight: 800;
}

.dropoff-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.dropoff-option {
  cursor: pointer;
  padding: 10px 12px;
  border: 1px solid #cbdadd;
  border-radius: 999px;
  color: #34505e;
  font-weight: 800;
  background: #fff;
}

.dropoff-option.active {
  color: #fff;
  border-color: #11636c;
  background: #11636c;
}

.dropoff-quick small {
  color: #647780;
}

.usage-summary,
.price-estimate {
  padding: 14px;
  border-radius: 12px;
  color: #164d56;
  font-weight: 800;
  background: #e9f5f4;
}

.place-editor {
  display: grid;
  gap: 10px;
}

.location-field {
  display: grid;
  gap: 8px;
}

.location-search-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
}

.place-google-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  justify-content: space-between;
  color: #647780;
  font-size: 0.88rem;
}

.place-chip-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  min-height: 44px;
  padding: 10px;
  border: 1px solid #dbe8ea;
  border-radius: 12px;
  background: #fff;
}

.place-chip {
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  max-width: 100%;
  padding: 8px 10px;
  border: 1px solid #cbdadd;
  border-radius: 999px;
  color: #304e58;
  font-size: 0.82rem;
  font-weight: 800;
  background: #f7fbfb;
}

.place-chip span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.place-chip b {
  color: #a33b1e;
}

.place-add-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
}

.place-route-list {
  display: grid;
  gap: 8px;
}

.place-route-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  padding: 12px;
  border: 1px solid #dbe8ea;
  border-radius: 14px;
  background: #fff;
}

.place-route-item span {
  display: block;
  margin-bottom: 4px;
  color: #3f8587;
  font-size: 0.74rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.place-route-item strong {
  color: #16313e;
}

.route-order-actions {
  display: flex;
  gap: 6px;
}

.route-order-actions button {
  cursor: pointer;
  display: grid;
  width: 34px;
  height: 34px;
  place-items: center;
  border: 1px solid #cbdadd;
  border-radius: 999px;
  color: #164d56;
  font-weight: 900;
  background: #f7fbfb;
}

.route-order-actions button:disabled {
  cursor: not-allowed;
  opacity: 0.35;
}

.vehicle-price-panel {
  display: grid;
  gap: 14px;
  padding: 18px;
  border: 1px solid #dbe8ea;
  border-radius: 16px;
  background: #f7faf9;
}

.vehicle-price-panel h2,
.vehicle-price-panel p {
  margin: 4px 0 0;
}

.first-day-panel {
  display: grid;
  gap: 14px;
  padding: 18px;
  border: 1px solid #dbe8ea;
  border-radius: 16px;
  background: #f7faf9;
}

.first-day-panel h2,
.first-day-panel p {
  margin: 4px 0 0;
}

.arrival-type-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.arrival-type-option {
  cursor: pointer;
  min-width: 150px;
  padding: 13px 16px;
  border: 1px solid #cbdadd;
  border-radius: 999px;
  color: #34505e;
  font-size: 1rem;
  font-weight: 900;
  background: #fff;
}

.arrival-type-option.active {
  color: #fff;
  border-color: #11636c;
  background: #11636c;
}

.simplified-first-day-card .first-day-panel h2 {
  margin-bottom: 8px;
}

.form-hint {
  margin: 8px 0 0;
  color: #5e737b;
  line-height: 1.55;
}

.first-day-optional-details {
  border: 1px solid #cfe2e6;
  border-radius: 18px;
  padding: 16px;
  background: #f8fcfc;
}

.first-day-optional-details summary {
  cursor: pointer;
  color: #0b5f66;
  font-weight: 900;
}

.first-day-optional-details[open] summary {
  margin-bottom: 16px;
}

.always-open-tour-details {
  padding-top: 0;
}

.always-open-tour-details > summary {
  display: none;
}

.nested-grid {
  margin: 0;
}

.arrival-confirm-box {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  padding: 14px;
  border-radius: 14px;
  color: #164d56;
  background: #e9f5f4;
}

.guided-next-action {
  position: relative;
  z-index: 2;
  outline: 4px solid rgba(255, 202, 58, 0.92);
  box-shadow: 0 0 0 8px rgba(255, 202, 58, 0.24), 0 18px 42px rgba(10, 82, 90, 0.2);
  animation: tripbusanGuidePulse 1.15s ease-in-out 4;
}

button.guided-next-action,
a.guided-next-action,
.primary-cta.guided-next-action,
.secondary-button-like.guided-next-action {
  background: #ffd84d;
  border-color: #ffd84d;
  color: #14313b;
  transform: translateY(-1px);
}

@keyframes tripbusanGuidePulse {
  0% { box-shadow: 0 0 0 0 rgba(255, 202, 58, 0.55), 0 18px 42px rgba(10, 82, 90, 0.16); }
  70% { box-shadow: 0 0 0 12px rgba(255, 202, 58, 0), 0 18px 42px rgba(10, 82, 90, 0.18); }
  100% { box-shadow: 0 0 0 0 rgba(255, 202, 58, 0), 0 18px 42px rgba(10, 82, 90, 0.16); }
}

.flight-list-box {
  display: grid;
  gap: 10px;
}

.flight-option-card {
  width: 100%;
  border: 1px solid rgba(15, 118, 110, 0.22);
  background: #fff;
  border-radius: 14px;
  padding: 14px 16px;
  text-align: left;
  cursor: pointer;
}

.flight-option-card:hover,
.flight-option-card:focus,
.flight-option-card.selected {
  border-color: #0f766e;
  box-shadow: 0 8px 20px rgba(15, 118, 110, 0.12);
}

.flight-option-card.selected {
  background: #e8f6f4;
  outline: 3px solid rgba(15, 118, 110, 0.18);
}

.flight-option-card strong {
  display: block;
  color: #122f3a;
  font-size: 1rem;
}

.flight-option-card span {
  display: block;
  margin-top: 4px;
  color: #5b7280;
  font-weight: 700;
}

.hotel-search-results {
  display: grid;
  gap: 8px;
  margin-top: 10px;
  padding: 10px;
  border: 1px solid #dbe8ea;
  border-radius: 14px;
  background: #f7faf9;
}

.hotel-result-button {
  cursor: pointer;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  width: 100%;
  padding: 10px 12px;
  border: 1px solid #d5e3e6;
  border-radius: 12px;
  background: #fff;
  color: #16313e;
  text-align: left;
}

.hotel-result-button span {
  color: #0b6f76;
  font-size: 0.85rem;
  font-weight: 800;
}

.hotel-confirmed {
  padding: 10px 12px;
  border-radius: 12px;
  background: #eaf7f5;
  color: #16313e;
}

.hotel-fallback-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}

.inline-chat-panel {
  display: grid;
  gap: 14px;
  margin-top: 22px;
  padding-top: 20px;
  border-top: 1px solid #dbe8ea;
}

.sns-verification-card {
  display: grid;
  gap: 10px;
  margin: 16px 0;
  padding: 18px;
  border: 1px solid #f1c4b8;
  border-radius: 18px;
  color: #17313b;
  background: #fff6f3;
}

.sns-verification-card span {
  color: #c95f4e;
  font-size: 0.74rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.sns-verification-card h3,
.sns-verification-card p {
  margin: 0;
}

.sns-verification-card p {
  color: #5d7079;
  line-height: 1.65;
}

.sns-verification-card strong {
  display: inline-flex;
  width: fit-content;
  align-items: center;
  justify-content: center;
  min-width: 132px;
  padding: 12px 18px;
  border-radius: 14px;
  color: #fff;
  font-size: 2rem;
  letter-spacing: 0.2em;
  background: #11384a;
}

.sns-verification-card.compact {
  margin: 10px 0;
  padding: 12px;
}

.sns-verification-card.compact h3 {
  font-size: 1.05rem;
}

.sns-verification-card.compact strong {
  min-width: 110px;
  padding: 10px 14px;
  font-size: 1.55rem;
}

.inline-chat-form {
  display: grid;
  gap: 10px;
}

.inline-chat-form textarea {
  width: 100%;
  resize: vertical;
}

.inline-chat-panel .chat-message-list {
  max-height: 420px;
  overflow: auto;
  padding-right: 4px;
}

.inline-chat-panel .chat-message-card small {
  color: #647780;
  line-height: 1.45;
}

.booking-chat-thread {
  display: grid;
  gap: 12px;
  padding: 16px;
  border: 1px solid #d9e7ea;
  border-radius: 20px;
  background: #f4f7fb;
}

.booking-chat-bubble {
  max-width: min(86%, 520px);
  padding: 14px 16px;
  border-radius: 18px;
  background: #fff;
  box-shadow: 0 10px 22px rgba(19, 55, 68, 0.08);
}

.booking-chat-bubble.mine {
  justify-self: end;
  color: #fff;
  background: #0f766e;
}

.booking-chat-bubble.system {
  justify-self: start;
  background: #fff;
}

.booking-chat-bubble.notice {
  max-width: 100%;
  justify-self: stretch;
  border: 1px solid #cbe3e6;
  background: #eaf7f5;
}

.inquiry-intro p,
.minimal-form-note,
.form-hint,
.memory-note,
.slider-help,
.inline-chat-note,
.reservation-code-card p,
.reservation-request-section > p:not(.eyebrow) {
  max-width: 760px;
  line-height: 1.55;
}

.booking-chat-meta {
  margin-bottom: 6px;
  color: #67808b;
  font-size: 0.74rem;
  font-weight: 900;
  letter-spacing: 0.04em;
}

.booking-chat-bubble.mine .booking-chat-meta,
.booking-chat-bubble.mine small {
  color: rgba(255, 255, 255, 0.78);
}

.booking-chat-bubble p {
  margin: 0;
  white-space: pre-wrap;
  line-height: 1.55;
}

.booking-chat-bubble small {
  display: block;
  margin-top: 8px;
  color: #60737b;
}

body.compact-chat-page {
  min-height: 100dvh;
  margin: 0;
  overflow-x: hidden;
  overflow-y: auto;
  background: #b8c7d8;
  padding-bottom: calc(82px + env(safe-area-inset-bottom)) !important;
}

body.compact-chat-page .site-header,
body.compact-chat-page .tripbusan-bottom-nav,
body.compact-chat-page .site-footer,
body.compact-chat-page .chat-language-note,
body.compact-chat-page .quick-chat-templates,
body.compact-chat-page #chat-post-booking-picks {
  display: none !important;
}

body.compact-chat-page .triptalk-main {
  display: grid;
  grid-template-rows: auto auto auto;
  width: min(100%, 430px);
  min-height: 100dvh;
  height: auto;
  max-width: 430px;
  margin: 0 auto;
  padding: 0 10px calc(82px + env(safe-area-inset-bottom));
  gap: 0;
  background: #b8c7d8;
}

body.compact-chat-page .explore-hero {
  position: static;
  z-index: 30;
  margin: 0 -10px;
  padding: calc(8px + env(safe-area-inset-top)) 12px 9px;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

body.compact-chat-page .explore-hero .eyebrow {
  display: none !important;
}

body.compact-chat-page .explore-hero h1 {
  margin: 0;
  font-size: 1.03rem;
  line-height: 1.18;
  letter-spacing: 0;
}

body.compact-chat-page .explore-hero p:not(.eyebrow) {
  display: grid;
  gap: 4px;
  margin: 5px 0 0;
  font-size: 0.78rem;
  line-height: 1.25;
}

body.compact-chat-page .explore-hero p:not(.eyebrow) span {
  display: block;
  padding: 5px 7px;
  border-radius: 9px;
  color: #17313a;
  background: #f2fbfa;
  overflow-wrap: anywhere;
}

body.compact-chat-page .explore-hero p:not(.eyebrow) strong {
  margin-right: 5px;
  color: #0b7b82;
}

body.compact-chat-page .chat-message-list {
  min-height: 0;
  max-height: none;
  margin: 0;
  padding: 12px 0 26px;
  overflow: visible;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
  scroll-padding-bottom: 120px;
}

body.compact-chat-page .chat-message-card,
body.compact-chat-page .booking-chat-bubble {
  max-width: 92%;
  padding: 10px 12px;
  border-radius: 16px;
  font-size: 0.9rem;
}

body.compact-chat-page .chat-message-card p,
body.compact-chat-page .booking-chat-bubble p {
  line-height: 1.42;
  overflow-wrap: anywhere;
}

body.compact-chat-page .inquiry-card {
  position: fixed;
  left: 50%;
  right: auto;
  bottom: 0;
  transform: translateX(-50%);
  z-index: 40;
  width: min(100%, 430px);
  margin: 0;
  padding: 8px 10px calc(8px + env(safe-area-inset-bottom));
  border-width: 1px 0 0;
  border-radius: 18px 18px 0 0;
  border-color: rgba(0, 0, 0, 0.08);
  background: #f7f7f7;
  box-shadow: 0 -2px 12px rgba(0, 0, 0, 0.08);
}

body.compact-chat-page #chat-form {
  display: grid;
  grid-template-columns: 34px 34px 34px minmax(0, 1fr) 54px;
  gap: 6px;
  align-items: center;
  min-height: 48px;
}

body.compact-chat-page #chat-form label:has(#chat-message) {
  grid-column: 4 / 5;
  grid-row: 1;
  font-size: 0;
}

body.compact-chat-page #chat-message {
  width: 100%;
  height: 44px !important;
  min-height: 44px;
  max-height: 44px;
  padding: 10px 13px;
  border: 1px solid #d8dde1;
  border-radius: 20px;
  background: #ffffff;
  color: #111111;
  font-size: 16px;
  line-height: 1.35;
  resize: none;
  overflow: hidden;
  box-shadow: none;
}

body.compact-chat-page #chat-form .submit-cta {
  grid-column: 5 / 6;
  grid-row: 1;
  min-height: 44px;
  margin: 0;
  padding: 0 8px;
  border-radius: 18px;
  background: #06c755;
  font-size: 0.78rem;
  line-height: 1.15;
  box-shadow: none;
}

body.compact-chat-page .chat-tool-button {
  grid-row: 1;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  width: 34px;
  min-height: 40px;
  padding: 0;
  border: 0;
  border-radius: 999px;
  color: #555555;
  background: transparent;
  font-size: 1.2rem;
  font-weight: 900;
  white-space: nowrap;
  overflow: hidden;
  cursor: pointer;
}

body.compact-chat-page #chat-more-button {
  grid-column: 1 / 2;
}

body.compact-chat-page .chat-camera-button {
  grid-column: 2 / 3;
}

body.compact-chat-page .chat-gallery-button {
  grid-column: 3 / 4;
}

body.compact-chat-page .chat-tool-button span {
  display: block;
  line-height: 1;
}

body.compact-chat-page #chat-image,
body.compact-chat-page #chat-camera {
  display: none !important;
}

body.compact-chat-page #send-image-button {
  display: none !important;
}

body.compact-chat-page #chat-error {
  grid-column: 1 / -1;
  margin: 0;
}

body.compact-chat-page .explore-hero {
  background: transparent;
  box-shadow: none;
  padding: calc(8px + env(safe-area-inset-top)) 10px 10px;
}

body.compact-chat-page .explore-hero h1 {
  display: none;
}

body.compact-chat-page #chat-summary {
  display: grid;
  gap: 6px;
  margin: 0;
  padding: 10px 11px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.45);
  color: #111111;
  box-shadow: none;
  font-size: 0.82rem;
}

body.compact-chat-page #chat-summary span {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr);
  gap: 8px;
  align-items: start;
  padding: 0;
  background: transparent;
  color: #111111;
}

body.compact-chat-page #chat-summary .chat-system-badge {
  display: none;
}

body.compact-chat-page #chat-summary strong {
  color: rgba(0, 0, 0, 0.58);
  font-weight: 900;
}

body.compact-chat-page #chat-summary em {
  min-width: 0;
  color: #111111;
  font-style: normal;
  font-weight: 850;
  line-height: 1.35;
  word-break: keep-all;
  overflow-wrap: anywhere;
}

body.compact-chat-page .chat-notification-prompt {
  position: fixed;
  left: 50%;
  bottom: calc(72px + env(safe-area-inset-bottom));
  transform: translateX(-50%);
  z-index: 52;
  display: grid;
  width: min(calc(100% - 24px), 390px);
  gap: 8px;
  padding: 13px 48px 13px 14px;
  border: 1px solid rgba(0, 0, 0, 0.08);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.96);
  color: #111111;
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.16);
}

body.compact-chat-page .chat-notification-prompt[hidden] {
  display: none !important;
}

body.compact-chat-page .chat-notification-prompt strong {
  font-size: 0.94rem;
  font-weight: 850;
}

body.compact-chat-page .chat-notification-prompt p {
  margin: 0;
  color: #4b5563;
  font-size: 0.82rem;
  line-height: 1.4;
}

body.compact-chat-page .chat-notification-prompt .primary-cta {
  width: fit-content;
  min-height: 34px;
  margin: 0;
  padding: 0 14px;
  border-radius: 999px;
  background: #06c755;
  font-size: 0.82rem;
  box-shadow: none;
}

body.compact-chat-page .chat-notification-close {
  position: absolute;
  top: 9px;
  right: 10px;
  display: inline-flex;
  width: 30px;
  height: 30px;
  align-items: center;
  justify-content: center;
  border: 0;
  border-radius: 999px;
  background: #f1f5f4;
  color: #334155;
  font-size: 1.1rem;
  font-weight: 850;
}

body.compact-chat-page .chat-message-list {
  display: flex;
  flex-direction: column;
  gap: 9px;
}

body.compact-chat-page .chat-message-card {
  width: fit-content;
  max-width: min(78%, 330px);
  border: 0;
  background: #fff;
  color: #111111;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.08);
  align-self: flex-start;
  border-bottom-left-radius: 6px;
}

body.compact-chat-page .chat-message-card.is-own-message {
  align-self: flex-end;
  border-bottom-right-radius: 6px;
  border-bottom-left-radius: 16px;
  background: #06c755;
  color: #fff;
}

body.compact-chat-page .chat-message-card.sender-customer,
body.compact-chat-page .chat-message-card.sender-owner,
body.compact-chat-page .chat-message-card.sender-admin {
  align-self: flex-start;
  background: #ffffff;
  color: #111111;
  border-bottom-left-radius: 6px;
  border-bottom-right-radius: 16px;
}

body.compact-chat-page .chat-message-card.sender-owner.is-own-message,
body.compact-chat-page .chat-message-card.sender-admin.is-own-message,
body.compact-chat-page .chat-message-card.sender-customer.is-own-message {
  align-self: flex-end;
  background: #06c755;
  color: #fff;
  border-bottom-right-radius: 6px;
  border-bottom-left-radius: 16px;
}

body.compact-chat-page .chat-message-card.sender-owner .chat-message-meta {
  color: #087d83;
  opacity: 1;
}

body.compact-chat-page .chat-message-card.sender-customer .chat-message-meta {
  color: rgba(255, 255, 255, 0.78);
  opacity: 1;
}

body.compact-chat-page .chat-message-card.sender-system {
  align-self: stretch;
  width: auto;
  max-width: none;
  border: 1px solid #cdebe6;
  background: #e9fbf7;
  color: #0d6466;
  box-shadow: none;
}

body.compact-chat-page .chat-message-card:not(.is-own-message):not(.sender-system) {
  border-bottom-left-radius: 6px;
}

body.compact-chat-page .chat-message-meta,
body.compact-chat-page .chat-message-card small,
body.compact-chat-page .chat-message-card summary {
  display: block;
  color: inherit;
  opacity: 0.72;
  font-size: 0.76rem;
  font-weight: 800;
}

body.compact-chat-page .chat-message-card p {
  margin: 0;
  color: inherit;
  font-size: 1rem;
  font-weight: 650;
}

body.compact-chat-page .chat-original-text {
  display: block;
  margin-top: 6px;
  color: inherit;
  opacity: 0.64;
  font-size: 0.78rem;
  line-height: 1.35;
}

body.compact-chat-page .chat-message-card details {
  margin-top: 7px;
}

body.compact-chat-page .chat-image-preview {
  width: min(100%, 260px);
  max-height: 260px;
  border-radius: 12px;
  object-fit: cover;
}

body.compact-chat-page[data-chat-role="owner"] .chat-message-card.is-own-message {
  background: #17313a;
}

.my-booking-list {
  display: grid;
  gap: 10px;
}

.my-booking-card {
  display: grid;
  width: 100%;
  gap: 4px;
  padding: 16px 18px;
  border: 1px solid #d7e5e8;
  border-radius: 18px;
  color: #16313c;
  text-align: left;
  background: #fff;
  cursor: pointer;
  box-shadow: 0 10px 22px rgba(19, 55, 68, 0.05);
}

.my-booking-card.active,
.my-booking-card:hover {
  border-color: #0f766e;
  background: #eefaf8;
}

.my-booking-card span,
.my-booking-card em {
  color: #0f766e;
  font-size: 0.76rem;
  font-style: normal;
  font-weight: 900;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.my-booking-card strong {
  font-size: 1.08rem;
}

.my-booking-card small {
  color: #60737b;
}

.lookup-inline-form {
  margin-top: 16px;
}

.reservation-confirmation-page {
  display: grid;
  gap: 18px;
  max-width: 760px;
  margin: 34px auto;
  padding: 0 0 28px;
  border-radius: 24px;
  background: #f7efe4;
}

.reservation-confirmation-hero {
  display: grid;
  justify-items: center;
  gap: 10px;
  padding: 34px 20px;
  border-radius: 24px 24px 0 0;
  color: #fff;
  text-align: center;
  background: #0f3145;
}

.reservation-confirmation-hero h2 {
  margin: 0;
  font-size: clamp(1.65rem, 5vw, 2.45rem);
}

.reservation-status-pill {
  display: inline-flex;
  align-items: center;
  padding: 9px 16px;
  border-radius: 999px;
  color: #16313e;
  font-weight: 900;
  background: #fff4bd;
}

.reservation-summary-card,
.reservation-code-card,
.inline-reservation-chat,
.post-complete-picks {
  margin: 0 20px;
  padding: 20px;
  border-radius: 22px;
  background: #fff;
  box-shadow: 0 18px 42px rgba(31, 51, 58, 0.09);
}

.reservation-summary-card > span,
.complete-menu-box span {
  color: #71838b;
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.reservation-summary-card > strong {
  display: block;
  margin: 8px 0 16px;
  color: #0f3145;
  font-size: clamp(1.35rem, 4vw, 2rem);
}

.reservation-summary-card dl {
  display: grid;
  gap: 12px;
  margin: 0;
  padding: 0 0 16px;
  border-bottom: 1px solid #eef2f3;
}

.reservation-summary-card dl div {
  display: flex;
  justify-content: space-between;
  gap: 18px;
}

.reservation-summary-card dt {
  color: #71838b;
  font-weight: 800;
}

.reservation-summary-card dd {
  margin: 0;
  color: #16313e;
  font-weight: 900;
  text-align: right;
}

.complete-menu-box {
  display: grid;
  gap: 8px;
  margin-top: 16px;
  color: #16313e;
  line-height: 1.6;
}

.reservation-code-card {
  border: 1px solid #f2c5ba;
  background: #fff7f5;
}

.reservation-code-card p {
  margin: 0 0 10px;
}

.inline-reservation-chat {
  overflow: hidden;
  padding: 0;
}

.inline-chat-header {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: center;
  padding: 16px 18px;
  color: #fff;
  background: #0f3145;
}

.inline-chat-messages {
  display: grid;
  align-content: start;
  gap: 10px;
  min-height: 280px;
  max-height: 440px;
  overflow-y: auto;
  padding: 16px;
  background: #f4f7fa;
}

.inline-chat-bubble {
  display: grid;
  gap: 5px;
  max-width: min(78%, 360px);
  padding: 12px 14px;
  border-radius: 18px;
  color: #173640;
  background: #fff;
}

.inline-chat-bubble.mine {
  justify-self: end;
  color: #fff;
  background: #0f3145;
  border-bottom-right-radius: 6px;
}

.inline-chat-bubble.theirs {
  justify-self: start;
  border-bottom-left-radius: 6px;
}

.inline-chat-bubble.system {
  justify-self: center;
  max-width: 92%;
  text-align: center;
  background: #eef2f4;
}

.inline-chat-bubble p,
.inline-chat-bubble em {
  margin: 0;
}

.inline-chat-bubble em,
.inline-chat-bubble time,
.inline-chat-bubble small {
  opacity: 0.75;
  font-size: 0.82rem;
}

.inline-chat-image {
  width: min(100%, 260px);
  max-height: 260px;
  object-fit: cover;
  border-radius: 14px;
}

.inline-chat-tools {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 12px 14px;
  border-top: 1px solid #eef2f3;
}

.inline-chat-input-row {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
  padding: 12px 14px;
  border-top: 1px solid #eef2f3;
  background: #fff;
}

.inline-chat-input-row input {
  min-height: 46px;
  padding: 0 14px;
  border: 1px solid #d7e3e6;
  border-radius: 14px;
}

.inline-photo-button {
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 0 14px;
  border-radius: 14px;
  color: #304e58;
  font-weight: 900;
  background: #eef3f4;
}

.danger-soft {
  color: #b42318;
  background: #fff0ef;
}

.inline-chat-note {
  margin: 0;
  padding: 0 16px 16px;
  color: #71838b;
  font-size: 0.86rem;
}

.post-complete-picks {
  background: #0f4f58;
  color: #fff;
}

.post-complete-picks p,
.post-complete-picks h2 {
  color: inherit;
}

.flight-time-notice {
  display: grid;
  gap: 7px;
  margin: 12px 0;
  padding: 12px;
  border: 1px solid #dbe8ea;
  border-radius: 14px;
  background: #f7faf9;
  color: #16313e;
}

.flight-time-notice.changed {
  border-color: #f2b8a2;
  background: #fff8f4;
}

.flight-time-notice strong,
.flight-time-notice p {
  margin: 0;
}

.flight-time-notice small {
  color: #647780;
}

.voucher-detail-list.compact {
  margin-top: 4px;
}

.vehicle-price-panel p:not(.eyebrow) {
  color: #647780;
  line-height: 1.55;
}

.vehicle-price-cards {
  display: grid;
  gap: 10px;
}

.vehicle-price-card {
  cursor: pointer;
  display: grid;
  gap: 6px;
  padding: 15px;
  border: 1px solid #d5e3e6;
  border-radius: 14px;
  color: #173640;
  text-align: left;
  background: #fff;
}

.vehicle-price-card span {
  color: #3f8587;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.vehicle-price-card strong {
  font-size: 1.1rem;
}

.vehicle-price-card small,
.vehicle-price-card em {
  color: #647780;
  font-size: 0.82rem;
  font-style: normal;
}

.vehicle-price-card.active {
  border-color: #11636c;
  outline: 3px solid rgba(17, 99, 108, 0.13);
}

.after-tour-panel {
  display: grid;
  gap: 14px;
  padding: 18px;
  border: 1px solid #e6d8c8;
  border-radius: 16px;
  background: #fff9f1;
}

.after-tour-panel h2,
.after-tour-panel p {
  margin: 4px 0 0;
}

.after-tour-panel p:not(.eyebrow) {
  color: #6c5a34;
  line-height: 1.55;
}

.after-tour-grid {
  display: grid;
  gap: 10px;
}

.after-tour-card {
  display: grid;
  gap: 7px;
  padding: 15px;
  border: 1px solid #eadcc9;
  border-radius: 14px;
  background: #fff;
}

.after-tour-card span {
  color: #a05c24;
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.after-tour-card strong,
.after-tour-card p {
  margin: 0;
}

.after-tour-card p {
  color: #647780;
  line-height: 1.5;
}

.review-next-step {
  display: grid;
  gap: 8px;
  margin-top: 22px;
  padding: 18px;
  border-radius: 14px;
  background: #eff7f6;
}

.review-next-step h3,
.review-next-step p {
  margin: 0;
}

.review-next-step p:not(.eyebrow) {
  color: #647780;
  line-height: 1.55;
}

.light-link {
  display: inline-flex;
  margin-top: 12px;
  color: #fff;
}

.inquiry-grid {
  display: grid;
  gap: 14px;
}

.reservation-request-section {
  max-width: 760px;
}

.reservation-request-section .inquiry-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.inquiry-grid label {
  display: grid;
  gap: 7px;
  color: #304e58;
  font-size: 0.86rem;
  font-weight: 700;
}

.inquiry-grid input,
.inquiry-grid select,
.inquiry-grid textarea {
  width: 100%;
  padding: 12px;
  border: 1px solid #cbdadd;
  border-radius: 9px;
  color: #16313e;
  background: #fff;
}

.reservation-request-section .inquiry-grid input,
.reservation-request-section .inquiry-grid select,
.reservation-request-section .inquiry-grid textarea {
  padding: 10px 11px;
}

.reservation-request-section .wide {
  grid-column: 1 / -1;
}

.reservation-translation-note {
  display: grid;
  gap: 4px;
  margin: 12px 0;
  padding: 12px 14px;
  border: 1px solid #cfe8e5;
  border-radius: 14px;
  background: #eefbf8;
  color: #07343c;
}

.reservation-translation-note strong {
  font-size: 0.98rem;
  font-weight: 900;
}

.reservation-translation-note span {
  color: #47636b;
  font-size: 0.9rem;
  font-weight: 700;
}

.reservation-open-notice {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  margin: 14px 0;
  padding: 12px 14px;
  border: 1px solid #dce7e9;
  border-radius: 14px;
  color: #16313e;
  background: #f6faf9;
}

.reservation-open-notice strong {
  font-size: 0.85rem;
  color: #667880;
}

.reservation-open-notice span {
  font-size: 1rem;
  font-weight: 900;
}

.reservation-open-notice.open {
  border-color: #9fd8b7;
  background: #eaf8ef;
}

.reservation-open-notice.closing-soon,
.reservation-open-notice.opening-soon {
  border-color: #f2d48d;
  background: #fff6dc;
}

.reservation-open-notice.closed {
  border-color: #f1b8a5;
  background: #fff0eb;
}

.submit-cta {
  cursor: pointer;
  border: 0;
}

.form-error {
  color: #b42318;
}

.inquiry-complete {
  margin-top: 24px;
}

.payment-summary dl {
  display: grid;
  gap: 12px;
  margin: 20px 0;
}

.payment-summary dt {
  color: #70818a;
  font-size: 0.76rem;
}

.payment-summary dd {
  margin: 3px 0 0;
  font-weight: 700;
}

.payment-total {
  display: grid;
  gap: 5px;
  margin: 22px 0;
  padding: 18px;
  border-radius: 12px;
  color: #fff;
  background: #164d56;
}

.payment-total strong {
  font-size: 1.8rem;
}

.payment-status {
  display: inline-block;
  padding: 5px 9px;
  border-radius: 999px;
  color: #8a5a0a;
  font-size: 0.78rem;
  font-weight: 800;
  background: #fff3d6;
}

.payment-status.paid {
  color: #17643b;
  background: #e5f6eb;
}

.payment-status.expired,
.payment-status.cancelled {
  color: #667880;
  background: #eff3f4;
}

.payment-instructions {
  white-space: pre-wrap;
}

.explore-hero {
  padding: 54px 0 20px;
}

.explore-hero p:last-child {
  max-width: 720px;
  color: #647780;
  line-height: 1.7;
}

.category-filter {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding: 10px 0 24px;
  cursor: grab;
  scroll-snap-type: x proximity;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}

.category-filter::-webkit-scrollbar,
.place-grid::-webkit-scrollbar,
.shorts-grid::-webkit-scrollbar {
  display: none;
}

.category-filter button {
  flex: 0 0 auto;
  scroll-snap-align: start;
  cursor: pointer;
  padding: 10px 12px;
  border: 1px solid #dce7e9;
  border-radius: 999px;
  color: #42666d;
  font-weight: 800;
  background: #fff;
}

.category-filter button.active {
  color: #fff;
  background: #11636c;
}

.explore-search-panel {
  display: flex;
  gap: 10px;
  align-items: center;
  margin: -6px 0 18px;
}

.explore-search-panel input {
  width: min(560px, 100%);
  min-height: 48px;
  border: 1px solid #d6e5e8;
  border-radius: 999px;
  padding: 0 18px;
  color: #15343d;
  background: #fff;
  font: inherit;
  font-weight: 800;
}

.explore-search-panel button {
  min-height: 48px;
  border: 1px solid #d6e5e8;
  border-radius: 999px;
  padding: 0 16px;
  color: #11636c;
  background: #fff;
  font-weight: 900;
  cursor: pointer;
}

.place-grid {
  display: flex;
  gap: 16px;
  overflow-x: auto;
  margin-bottom: 28px;
  padding: 2px 0 16px;
  cursor: grab;
  scroll-snap-type: x proximity;
  -webkit-overflow-scrolling: touch;
}

.explore-sections {
  display: grid;
  gap: 36px;
  padding-bottom: 40px;
}

.explore-category-section {
  display: grid;
  gap: 14px;
}

.section-heading-row {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 18px;
}

.section-heading-row h2 {
  margin: 0;
  color: #123f48;
  font-size: clamp(1.55rem, 3vw, 2.25rem);
}

.section-heading-row p:last-child {
  margin: 6px 0 0;
  color: #647780;
}

.explore-row-slider {
  display: flex;
  gap: 16px;
  overflow-x: auto;
  padding: 2px 0 18px;
  cursor: grab;
  scroll-snap-type: x proximity;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}

.explore-row-slider::-webkit-scrollbar {
  display: none;
}

.filter-label {
  width: min(1120px, calc(100% - 40px));
  margin: 18px auto 8px;
  color: #0a5962;
  font-size: 0.82rem;
  font-weight: 950;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.explore-category-filter {
  margin-top: 0;
}

.explore-result-list {
  width: min(920px, calc(100% - 40px));
  margin: 22px auto 44px;
  display: grid;
  gap: 14px;
}

.explore-list-heading {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 16px;
  padding: 4px 0 8px;
}

.explore-list-heading h2,
.explore-list-heading p {
  margin: 0;
}

.explore-list-heading h2 {
  color: #102f3a;
  font-size: clamp(1.75rem, 5vw, 3rem);
  letter-spacing: -0.055em;
  line-height: 1;
}

.explore-list-heading p {
  margin-top: 8px;
  color: #607780;
  line-height: 1.5;
}

.explore-list-heading > strong {
  flex: 0 0 auto;
  padding: 8px 12px;
  border-radius: 999px;
  background: #eef8f7;
  color: #0b5961;
  font-size: 0.86rem;
}

.explore-list-card {
  position: relative;
  overflow: hidden;
  border: 1px solid #d9e7e9;
  border-radius: 24px;
  background: #fff;
  box-shadow: 0 18px 42px rgba(19, 68, 78, 0.08);
}

.explore-list-card.compact-explore-card {
  border-radius: 20px;
}

.explore-list-card-link {
  display: grid;
  grid-template-columns: minmax(132px, 220px) 1fr;
  gap: 16px;
  padding: 14px;
  color: inherit;
  text-decoration: none;
}

.compact-explore-card .explore-list-card-link {
  display: block;
  padding: 0;
}

.explore-list-photo {
  position: relative;
  min-height: 154px;
  border-radius: 18px;
  overflow: hidden;
  background:
    linear-gradient(180deg, rgba(9, 34, 42, 0.08), rgba(9, 34, 42, 0.18)),
    var(--hot-spot-image) center / cover no-repeat,
    linear-gradient(135deg, #0f626d, #092834);
}

.compact-explore-card .explore-list-photo {
  min-height: 230px;
  border-radius: 20px 20px 0 0;
  background:
    linear-gradient(180deg, rgba(9, 34, 42, 0.08), rgba(9, 34, 42, 0.18)),
    linear-gradient(135deg, #0f626d, #092834);
}

.compact-explore-card .explore-list-photo::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  border-radius: inherit;
  background: var(--hot-spot-image) var(--hot-spot-position, center) / cover no-repeat;
  transform: scale(var(--hot-spot-zoom, 1));
  transform-origin: center center;
  will-change: transform;
  pointer-events: none;
}

.explore-list-photo::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: linear-gradient(180deg, rgba(5, 22, 30, 0.03) 35%, rgba(5, 22, 30, 0.78) 100%);
  pointer-events: none;
}

.explore-list-overlay {
  position: absolute;
  right: 14px;
  bottom: 14px;
  left: 14px;
  z-index: 1;
  display: grid;
  gap: 6px;
  color: #fff;
}

.explore-list-body {
  display: grid;
  align-content: center;
  gap: 8px;
  min-width: 0;
  padding-right: 126px;
}

.explore-list-title-row {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 12px;
}

.explore-list-title-row h2 {
  margin: 0;
  color: #102f3a;
  font-size: clamp(1.22rem, 4.5vw, 1.75rem);
  line-height: 1.1;
  letter-spacing: -0.04em;
}

.explore-list-overlay .explore-list-title-row h2 {
  color: #fff;
  font-size: clamp(1.25rem, 6vw, 1.9rem);
  text-shadow: 0 2px 12px rgba(0, 0, 0, 0.35);
}

.explore-list-title-row span {
  flex: 0 0 auto;
  color: #163844;
  font-weight: 950;
  white-space: nowrap;
}

.explore-list-overlay .explore-list-title-row span,
.explore-list-overlay .explore-list-meta {
  color: #fff;
  text-shadow: 0 2px 10px rgba(0, 0, 0, 0.32);
}

.explore-list-title-row .place-rating-stack {
  display: inline-flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 7px;
  min-width: max-content;
  line-height: 1.04;
}

.explore-list-title-row .place-rating-stack b {
  font: inherit;
}

.explore-list-title-row .place-rating-stack small {
  color: inherit;
  font-size: 0.64rem;
  font-weight: 900;
  line-height: 1.1;
  margin-top: 3px;
  white-space: nowrap;
  opacity: 0.96;
}

.explore-list-meta,
.explore-list-intro {
  margin: 0;
  color: #5b7380;
  line-height: 1.45;
}

.explore-list-meta-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.explore-list-meta-row .explore-list-meta {
  min-width: 0;
  margin: 0;
}

.explore-list-meta-row .place-rating-stack {
  flex: 0 0 auto;
  margin-top: -2px;
}

.explore-list-intro {
  color: #244c57;
  font-weight: 800;
}

.explore-list-body small {
  color: #607780;
  font-weight: 800;
}

.explore-list-actions {
  position: absolute;
  right: 14px;
  bottom: 14px;
  display: flex;
  gap: 8px;
}

.explore-heart-button {
  position: absolute;
  top: 12px;
  right: 12px;
  z-index: 2;
  display: grid;
  width: 42px;
  height: 42px;
  place-items: center;
  border: 0;
  border-radius: 999px;
  color: #fff;
  font-size: 1.55rem;
  font-weight: 900;
  background: rgba(4, 20, 27, 0.5);
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.18);
  cursor: pointer;
}

.explore-heart-button.is-saved,
.explore-heart-button.saved {
  color: #ffef6b;
  background: rgba(13, 112, 120, 0.92);
}

.explore-list-mini-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  padding: 10px 12px 12px;
  color: #44616b;
  font-size: 0.82rem;
  font-weight: 900;
}

.explore-save-button,
.explore-reserve-button {
  min-height: 42px;
  padding: 10px 14px;
  border-radius: 999px;
  font-size: 0.92rem;
}

.explore-save-button.is-saved {
  border-color: #0b7881;
  color: #fff;
  background: #0b7881;
}

.place-card {
  flex: 0 0 min(320px, 82vw);
  scroll-snap-align: start;
  overflow: hidden;
  border: 1px solid #dce7e9;
  border-radius: 16px;
  background: #fff;
}

.home-drag-slider.is-dragging {
  cursor: grabbing;
  user-select: none;
}

.home-drag-slider.is-dragging a,
.home-drag-slider.is-dragging button {
  pointer-events: none;
}

.place-card img {
  width: 100%;
  height: 180px;
  object-fit: cover;
}

.place-card-photo-fallback {
  height: 180px;
  background:
    radial-gradient(circle at 25% 20%, rgba(255, 255, 255, 0.3), transparent 25%),
    linear-gradient(135deg, #174d56, #12232e 70%);
}

.place-card > div {
  display: grid;
  gap: 8px;
  padding: 18px;
}

.place-card span,
.place-card small {
  color: #70818a;
  font-size: 0.78rem;
}

.listing-badge {
  display: inline-flex;
  margin-left: 6px;
  padding: 3px 7px;
  border-radius: 999px;
  font-size: 0.68rem;
  font-weight: 800;
  vertical-align: middle;
}

.listing-badge.listing-verified {
  color: #17643b;
  background: #e5f6eb;
}

.listing-badge.listing-partner {
  color: #135f8f;
  background: #e6f3fb;
}

.listing-badge.listing-featured {
  color: #8a4b0a;
  background: #fff0d9;
}

.listing-badge.listing-partner {
  color: #135f8f;
  background: #e6f3fb;
}

.listing-badge.listing-basic {
  color: #667880;
  background: #eff3f4;
}

.open-status {
  display: inline-flex;
  align-items: center;
  padding: 4px 9px;
  border-radius: 999px;
  color: #667880;
  font-weight: 900;
  background: #eff3f4;
}

.open-status.open {
  color: #17643b;
  background: #e5f6eb;
}

.open-status.closing-soon,
.open-status.opening-soon {
  color: #8a5a0a;
  background: #fff3d6;
}

.open-status.closed {
  color: #a33b1e;
  background: #fde9df;
}

.final-day-box {
  margin-top: 28px;
}

.final-day-options {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}

.final-day-slider {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(240px, 0.36fr);
  gap: 14px;
  overflow-x: auto;
  overscroll-behavior-x: contain;
  scroll-snap-type: x mandatory;
  padding: 6px 4px 14px;
  cursor: grab;
}

.final-day-card {
  display: grid;
  align-content: end;
  min-height: 190px;
  padding: 18px;
  border-radius: 18px;
  color: #fff;
  text-decoration: none;
  scroll-snap-align: start;
  background:
    radial-gradient(circle at 20% 20%, rgba(255, 255, 255, 0.3), transparent 24%),
    linear-gradient(140deg, #0a6973, #0f2635 68%, #160f22);
  box-shadow: 0 16px 34px rgba(18, 63, 72, 0.18);
}

.final-day-card span {
  color: rgba(255, 255, 255, 0.78);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.final-day-card strong {
  margin-top: 8px;
  font-size: 1.3rem;
  line-height: 1.1;
}

.final-day-card p {
  margin: 10px 0 0;
  color: rgba(255, 255, 255, 0.86);
}

.transport-actions {
  width: 100%;
  margin-top: 10px;
}

.hero-transport-box {
  display: grid;
  gap: 10px;
  max-width: 620px;
  margin-top: 14px;
  padding: 14px;
  border: 1px solid #cfe2e4;
  border-radius: 16px;
  background: #f2faf9;
}

.hero-transport-box strong {
  color: #16313e;
  font-size: 0.9rem;
}

.taxi-action-button {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  min-height: 46px;
  padding: 12px 16px;
  border-radius: 12px;
  color: #fff;
  font-weight: 900;
  text-decoration: none;
  box-shadow: 0 10px 22px rgba(17, 99, 108, 0.16);
}

.taxi-action-button.uber {
  background: #111;
}

.taxi-action-button.kakao {
  color: #231815;
  background: #fee500;
}

.explore-info-card .transport-actions {
  margin-top: 14px;
}

.sns-next-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin: 18px 0;
}

.contact-choice-card {
  cursor: pointer;
  display: grid;
  gap: 5px;
  width: 100%;
  padding: 15px;
  border: 1px solid #dce7e9;
  border-radius: 16px;
  color: #16313e;
  text-align: left;
  background: #fff;
}

.contact-choice-card.primary-choice {
  color: #fff;
  background: #11636c;
}

.contact-choice-card strong {
  font-size: 1rem;
}

.contact-choice-card span {
  color: inherit;
  opacity: 0.78;
  font-size: 0.86rem;
}

.phone-choice {
  grid-column: 1 / -1;
}

.phone-capture-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  margin-top: 8px;
}

.phone-capture-row input,
.phone-capture-row button {
  min-height: 42px;
  padding: 0 12px;
  border: 1px solid #cbdadd;
  border-radius: 12px;
}

.phone-capture-row button {
  cursor: pointer;
  color: #fff;
  font-weight: 900;
  background: #0f3145;
}

.wechat-contact-guide {
  grid-column: 1 / -1;
  padding: 14px;
  border: 1px solid #dce7e9;
  border-radius: 16px;
  background: #f7faf9;
}

.wechat-contact-guide p {
  margin: 6px 0;
}

.wechat-contact-guide code {
  display: block;
  padding: 12px;
  border-radius: 12px;
  color: #fff;
  font-weight: 900;
  background: #0f3145;
}

.contact-link-status {
  display: inline-flex;
  padding: 8px 12px;
  border-radius: 999px;
  color: #8a5a0a;
  font-weight: 900;
  background: #fff3d6;
}

.contact-link-status.linked {
  color: #17643b;
  background: #e5f6eb;
}

.contact-link-status.error {
  color: #b42318;
  background: #fff0ef;
}

.booking-message-code {
  display: block;
  width: fit-content;
  max-width: 100%;
  margin: 14px 0;
  padding: 14px 16px;
  border-radius: 14px;
  background: #102f3a;
  color: #fff;
  font-size: clamp(1rem, 3vw, 1.4rem);
  font-weight: 900;
  letter-spacing: 0.03em;
  white-space: normal;
}

.triptalk-role-grid,
.schedule-v2-grid,
.day-plan-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 16px;
}

.triptalk-role-grid article,
.schedule-v2-grid article,
.day-plan-list article {
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 22px;
  background: #fff;
  box-shadow: var(--shadow-soft);
}

.triptalk-role-grid span,
.schedule-v2-grid span,
.day-plan-list span {
  display: block;
  color: var(--teal);
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
  margin-bottom: 8px;
}

.place-card h2,
.place-card p {
  margin: 0;
}

.place-card p {
  color: #647780;
  line-height: 1.6;
}

.place-actions {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
}

.secondary-link {
  color: #11636c;
  font-weight: 800;
  text-decoration: none;
}

.partner-sales-card,
.chat-language-note {
  display: grid;
  gap: 8px;
  margin-bottom: 22px;
  padding: 22px;
  border: 1px solid #cfe2e4;
  border-radius: 16px;
  background: #eff7f6;
}

.compact-sales-card {
  padding: 18px 20px;
}

.compact-sales-card h2 {
  font-size: clamp(1.2rem, 3vw, 1.9rem);
}

.partner-sales-card h2,
.partner-sales-card p,
.chat-language-note h2,
.chat-language-note p {
  margin: 0;
}

.explore-detail-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(260px, 420px);
  gap: 28px;
  align-items: end;
  padding: 54px 0 20px;
}

.explore-detail-hero p:last-child {
  max-width: 760px;
  color: #647780;
  line-height: 1.7;
}

.explore-hero-photo-button {
  display: block;
  width: 100%;
  padding: 0;
  border: 0;
  border-radius: 24px;
  overflow: hidden;
  background: #e8f0f2;
  box-shadow: 0 20px 48px rgba(22, 49, 62, 0.16);
  cursor: zoom-in;
}

.explore-hero-photo {
  display: block;
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
}

.explore-photo-strip {
  display: flex;
  gap: 12px;
  overflow-x: auto;
  padding-bottom: 10px;
}

.explore-photo-strip img,
.photo-placeholder {
  flex: 0 0 250px;
  width: 250px;
  height: 180px;
  border-radius: 16px;
  object-fit: cover;
  background: #e8f0f2;
}

.customer-zoom-image {
  cursor: zoom-in;
}

.customer-zoom-image:focus-visible {
  outline: 3px solid #0f7b82;
  outline-offset: 3px;
}

.customer-image-preview-modal {
  position: fixed;
  inset: 0;
  z-index: 5000;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 18px;
  background: rgba(5, 22, 30, 0.86);
}

.customer-image-preview-modal.is-open {
  display: flex;
}

.customer-image-preview-dialog {
  position: relative;
  display: grid;
  width: min(980px, 96vw);
  max-height: 92vh;
}

.customer-image-preview-dialog img {
  width: 100%;
  max-height: 78vh;
  object-fit: contain;
  border-radius: 18px;
  background: #eef4f5;
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.32);
}

.customer-image-preview-caption {
  display: grid;
  gap: 6px;
  margin-top: 10px;
  padding: 13px 15px;
  border-radius: 16px;
  color: #0b3338;
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 18px 48px rgba(0, 0, 0, 0.22);
}

.customer-image-preview-caption[hidden] {
  display: none;
}

.customer-image-preview-caption strong {
  font-size: 1.12rem;
  font-weight: 950;
  line-height: 1.2;
}

.customer-image-preview-caption span {
  color: #087a80;
  font-size: 1rem;
  font-weight: 950;
}

.customer-image-preview-close {
  position: absolute;
  top: -12px;
  right: -8px;
  z-index: 1;
  display: grid;
  width: 44px;
  height: 44px;
  place-items: center;
  border: 0;
  border-radius: 999px;
  color: #fff;
  font-size: 1.7rem;
  font-weight: 900;
  line-height: 1;
  background: #0d7078;
  box-shadow: 0 10px 26px rgba(0, 0, 0, 0.24);
  cursor: pointer;
}

.customer-image-preview-nav {
  position: absolute;
  top: 50%;
  z-index: 2;
  display: grid;
  width: 48px;
  height: 48px;
  place-items: center;
  border: 0;
  border-radius: 999px;
  color: #fff;
  font-size: 2rem;
  font-weight: 900;
  line-height: 1;
  background: rgba(13, 112, 120, 0.92);
  box-shadow: 0 10px 26px rgba(0, 0, 0, 0.24);
  transform: translateY(-50%);
  cursor: pointer;
}

.customer-image-preview-prev {
  left: -18px;
}

.customer-image-preview-next {
  right: -18px;
}

.photo-placeholder {
  display: grid;
  place-items: center;
  color: #647780;
  font-weight: 800;
}

.explore-menu-section {
  display: none !important;
}

.reservation-menu-picker {
  display: grid;
  gap: 10px;
  margin: 16px 0;
}

.reservation-menu-row {
  display: grid;
  grid-template-columns: 72px minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  padding: 10px;
  border: 1px solid #d6e4e7;
  border-radius: 16px;
  background: #fff;
}

.reservation-menu-row img,
.reservation-menu-row .compact-menu-photo-placeholder {
  width: 72px;
  height: 72px;
  border-radius: 12px;
  object-fit: cover;
}

.reservation-menu-info {
  display: grid;
  gap: 4px;
}

.reservation-menu-info strong {
  color: #16313e;
  font-size: 1rem;
}

.reservation-menu-info span {
  color: #0b6670;
  font-size: 0.92rem;
  font-weight: 900;
}

.explore-detail-grid,
.menu-grid,
.chat-message-list {
  display: grid;
  gap: 14px;
}

.shorts-grid {
  display: flex;
  gap: 14px;
  overflow-x: auto;
  padding-bottom: 12px;
  cursor: grab;
  scroll-snap-type: x proximity;
  -webkit-overflow-scrolling: touch;
}

.explore-info-card,
.menu-card,
.chat-message-card {
  padding: 18px;
  border: 1px solid #dce7e9;
  border-radius: 16px;
  background: #fff;
}

.menu-card {
  overflow: hidden;
}

.menu-card.photo-menu-card {
  display: grid;
  gap: 0;
  padding: 0;
  border-radius: 18px;
}

.menu-photo-button {
  cursor: zoom-in;
  display: block;
  width: 100%;
  padding: 0;
  border: 0;
  background: transparent;
}

.menu-card.photo-menu-card .menu-photo-button img {
  display: block;
  width: 100%;
  height: clamp(190px, 52vw, 280px);
  object-fit: cover;
  background: #eef4f5;
}

.menu-card.photo-menu-card > div {
  display: grid;
  gap: 7px;
  padding: 13px 14px 14px;
}

.menu-card.photo-menu-card strong {
  color: #16313e;
  font-size: 1.03rem;
  line-height: 1.25;
}

.menu-card.photo-menu-card p {
  margin: 0;
  color: #5e767d;
  font-size: 0.9rem;
  line-height: 1.45;
}

.menu-card.photo-menu-card span {
  color: #11636c;
  font-size: 0.94rem;
  font-weight: 900;
}

.menu-card.text-menu-row {
  display: grid;
  padding: 12px 14px;
  border-radius: 13px;
}

.menu-card.text-menu-row > div {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  align-items: center;
  gap: 8px;
  padding: 0;
}

.menu-card.text-menu-row strong {
  overflow: hidden;
  color: #16313e;
  font-size: 0.95rem;
  line-height: 1.3;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.menu-card.text-menu-row p {
  display: none;
}

.menu-card.text-menu-row span {
  color: #11636c;
  font-size: 0.88rem;
  font-weight: 900;
  white-space: nowrap;
}

.menu-card.compact-menu-row {
  display: grid;
  grid-template-columns: 58px minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  padding: 8px;
}

.menu-card.compact-menu-row > img {
  grid-row: 1 / span 2;
  width: 58px;
  height: 58px;
  border-radius: 10px;
  object-fit: cover;
}

.compact-menu-photo-placeholder {
  grid-row: 1 / span 2;
  display: grid;
  width: 58px;
  height: 58px;
  place-items: center;
  border-radius: 10px;
  color: #71838b;
  font-size: 0.68rem;
  font-weight: 900;
  text-align: center;
  background: #eef4f5;
}

.menu-card.compact-menu-row > div {
  display: contents;
}

.menu-card.compact-menu-row strong {
  min-width: 0;
  overflow: hidden;
  color: #16313e;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.menu-card.compact-menu-row p {
  display: none;
}

.menu-card.compact-menu-row span {
  color: #11636c;
  font-size: 0.9rem;
  font-weight: 900;
  white-space: nowrap;
}

.menu-card.compact-menu-row .compact-menu-order {
  display: grid;
  grid-template-columns: 38px 58px 38px;
  gap: 6px;
  align-items: center;
}

.reservation-menu-row .compact-menu-order {
  display: grid;
  grid-template-columns: 34px 40px 34px;
  gap: 5px;
  align-items: center;
}

.menu-card.compact-menu-row .compact-menu-quantity {
  display: contents;
}

.menu-card.compact-menu-row .compact-menu-quantity input,
.menu-card.compact-menu-row [data-menu-quantity],
.reservation-menu-row [data-menu-quantity] {
  width: 58px;
  min-height: 36px;
  padding: 7px;
  border: 1px solid #cbd8dd;
  border-radius: 9px;
  text-align: center;
}

.menu-count-button,
.menu-add-button {
  cursor: pointer;
  display: grid;
  width: 38px;
  height: 36px;
  place-items: center;
  border: 0;
  border-radius: 10px;
  color: #fff;
  font-size: 1.2rem;
  font-weight: 900;
  background: #11636c;
}

.menu-minus-button {
  color: #11636c;
  background: #e8f5f4;
  box-shadow: inset 0 0 0 1px rgba(17, 99, 108, 0.16);
}

.reservation-menu-row .menu-count-button,
.reservation-menu-row .menu-add-button {
  width: 34px;
  height: 36px;
  background: #0a7f84;
  font-size: 1.35rem;
  box-shadow: 0 8px 18px rgba(10, 127, 132, 0.24);
}

.reservation-menu-row .menu-minus-button {
  color: #0a6970;
  background: #e8f5f4;
  box-shadow: inset 0 0 0 1px rgba(10, 127, 132, 0.16);
}

.selected-menu-field {
  display: none;
  gap: 7px;
  margin-bottom: 14px;
  color: #304e58;
  font-size: 0.86rem;
  font-weight: 800;
}

.selected-menu-field textarea {
  width: 100%;
  min-height: 68px;
  padding: 12px;
  border: 1px solid #cbdadd;
  border-radius: 10px;
  color: #16313e;
  background: #eef8f8;
}

.menu-card img {
  width: 100%;
  height: 160px;
  object-fit: cover;
}

.menu-card > div {
  display: grid;
  gap: 8px;
  padding: 16px;
}

.menu-card p,
.explore-info-card p,
.chat-message-card p {
  color: #647780;
  line-height: 1.55;
}

.menu-card span {
  color: #11636c;
  font-weight: 800;
}

.menu-quantity {
  max-width: 130px;
}

.transport-pill {
  display: inline-flex;
  align-items: center;
  padding: 10px 12px;
  border-radius: 999px;
  color: #34505e;
  font-weight: 800;
  background: #eef4f5;
}

.shorts-card {
  display: grid;
  flex: 0 0 min(280px, 78vw);
  scroll-snap-align: start;
  min-height: 120px;
  place-items: center;
  border-radius: 16px;
  color: #fff;
  font-weight: 800;
  text-decoration: none;
  background: linear-gradient(135deg, #164d56, #e06b2d);
}

.shorts-embed-card {
  flex: 0 0 min(260px, 76vw);
  scroll-snap-align: start;
  overflow: hidden;
  border: 1px solid #dce7e9;
  border-radius: 18px;
  background: #fff;
  box-shadow: 0 12px 32px rgba(22, 77, 86, 0.08);
}

.shorts-embed-card iframe {
  display: block;
  width: 100%;
  aspect-ratio: 9 / 16;
  min-height: 420px;
  border: 0;
  background: #0f1e24;
}

.shorts-embed-card a {
  display: block;
  padding: 12px 14px;
  color: #11636c;
  font-weight: 900;
  text-decoration: none;
}

.youtube-wide-slider {
  display: flex;
  gap: 16px;
  overflow-x: auto;
  padding: 4px 0 16px;
  scroll-snap-type: x proximity;
  -webkit-overflow-scrolling: touch;
}

.youtube-wide-slider::-webkit-scrollbar {
  display: none;
}

.youtube-wide-card {
  flex: 0 0 min(520px, 86vw);
  overflow: hidden;
  border: 1px solid #dce7e9;
  border-radius: 18px;
  color: #16313e;
  text-decoration: none;
  background: #fff;
  scroll-snap-align: start;
  box-shadow: 0 12px 32px rgba(22, 77, 86, 0.08);
}

.youtube-wide-card iframe {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  border: 0;
  background: #0f1e24;
}

.youtube-wide-card > a,
.youtube-wide-card > strong,
.youtube-wide-card > span {
  display: block;
  padding: 12px 14px;
  color: #11636c;
  font-weight: 900;
  text-decoration: none;
}

.reservation-menu-row [data-menu-quantity] {
  width: 40px;
  min-height: 36px;
  padding: 5px;
  font-size: 0.82rem;
}

.always-visible-media-section {
  padding: 16px;
  border: 1px solid rgba(9, 85, 93, 0.14);
  border-radius: 22px;
  background: #fff;
  box-shadow: 0 14px 32px rgba(10, 62, 68, 0.08);
}

.always-visible-media-section h2,
.google-review-visible-block h2 {
  margin: 0 0 12px;
  color: #0b3338;
  font-size: 1.16rem;
}

.always-visible-media-section .youtube-wide-card {
  flex-basis: min(680px, 92vw);
}

.always-visible-media-section .youtube-wide-card iframe {
  min-height: 230px;
}

.optional-media-section .media-lookup-details {
  border: 1px solid rgba(9, 85, 93, 0.14);
  border-radius: 18px;
  background: #fff;
  box-shadow: 0 12px 26px rgba(10, 62, 68, 0.07);
}

.optional-media-section .media-search-button {
  width: 100%;
  justify-content: center;
}

.reservation-time-field {
  grid-column: 1 / -1;
}

.reservation-time-chips {
  display: flex;
  gap: 7px;
  overflow-x: auto;
  margin-top: 8px;
  padding-bottom: 2px;
  scrollbar-width: none;
}

.reservation-time-chips::-webkit-scrollbar {
  display: none;
}

.reservation-time-chips button {
  flex: 0 0 auto;
  min-width: 62px;
  min-height: 36px;
  border: 1px solid rgba(10, 127, 132, 0.2);
  border-radius: 999px;
  color: #0b5960;
  font-weight: 900;
  background: #eef8f8;
}

.reservation-time-chips button.active {
  color: #ffffff;
  border-color: #0a7f84;
  background: #0a7f84;
  box-shadow: 0 8px 18px rgba(10, 127, 132, 0.2);
}

.reservation-time-chips button:disabled {
  cursor: not-allowed;
  color: #8aa0a7;
  background: #edf1f2;
  opacity: 0.55;
}

.place-map-block {
  display: grid;
  gap: 7px;
  margin: 10px 0 12px;
}

.place-map-block iframe {
  width: 100%;
  min-height: 240px;
  border: 0;
  border-radius: 18px;
  background: #e8f0f2;
  box-shadow: 0 10px 24px rgba(22, 77, 86, 0.08);
}

.place-travel-metrics {
  display: grid;
  gap: 3px;
  color: #60757d;
  font-size: 0.76rem;
  font-weight: 700;
  line-height: 1.45;
}

.google-review-visible-block .slider-arrow-bar {
  display: none !important;
}

.google-review-load-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
}

.google-review-load-button span {
  font-size: 1.05em;
  font-weight: 950;
  line-height: 1;
}

.chat-message-card {
  display: grid;
  gap: 7px;
}

.chat-message-card span {
  color: #3f8587;
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.chat-message-card strong,
.chat-message-card p {
  margin: 0;
}

.chat-image-preview {
  display: block;
  width: min(100%, 260px);
  max-height: 220px;
  object-fit: cover;
  border: 1px solid #dce7e9;
  border-radius: 14px;
}

.partner-dashboard-hero {
  padding: 24px;
  border: 1px solid #dce7e9;
  border-radius: 22px;
  background: linear-gradient(135deg, #0f3f48, #16717a);
  color: #fff;
}

.partner-dashboard-hero h2,
.partner-dashboard-hero p {
  margin: 0;
}

.partner-dashboard-hero h2 {
  margin-bottom: 8px;
  font-size: clamp(1.5rem, 3vw, 2.2rem);
}

.metric-xl-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 14px;
}

.metric-xl-card {
  padding: 22px;
  border: 1px solid #dce7e9;
  border-radius: 20px;
  background: #fff;
  box-shadow: 0 16px 36px rgba(20, 55, 65, 0.08);
}

.metric-xl-card strong {
  display: block;
  color: #0f3f48;
  font-size: clamp(2rem, 4vw, 3.2rem);
  line-height: 1;
}

.metric-xl-card p {
  margin: 10px 0 0;
  color: #647780;
  font-weight: 800;
}

.owner-chat-alert {
  border-color: #bfdfe3;
  background: linear-gradient(135deg, #f2fbfb, #ffffff);
}

.owner-chat-alert.has-unread {
  border-color: #f2b8a2;
  background:
    radial-gradient(circle at 92% 12%, rgba(224, 107, 45, 0.22), transparent 28%),
    linear-gradient(135deg, #fff7ef, #ffffff);
  box-shadow: 0 18px 42px rgba(224, 107, 45, 0.14);
}

.owner-chat-alert.has-unread h2 {
  color: #b83a18;
}

.chat-unread-card {
  border-color: #f2b8a2;
  background: #fff8f4;
}

.partner-inquiry-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(300px, 0.75fr);
  gap: 28px;
  align-items: stretch;
  padding: 56px 6vw 32px;
  background:
    radial-gradient(circle at 80% 20%, rgba(224, 107, 45, 0.2), transparent 26%),
    linear-gradient(135deg, #eff8f8, #fff7ef);
}

.partner-inquiry-hero h1 {
  max-width: 820px;
  margin: 10px 0 18px;
  color: #0f3f48;
  font-size: clamp(2.4rem, 6vw, 5.2rem);
  line-height: 0.98;
  letter-spacing: -0.06em;
}

.partner-inquiry-hero p {
  max-width: 720px;
  color: #405a64;
  font-size: 1.08rem;
  line-height: 1.7;
}

.partner-proof-card {
  display: grid;
  gap: 14px;
  align-content: start;
  padding: 24px;
  border: 1px solid rgba(17, 99, 108, 0.16);
  border-radius: 28px;
  background: #fff;
  box-shadow: 0 24px 60px rgba(20, 55, 65, 0.12);
}

.partner-proof-card > span {
  color: #3f8587;
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.partner-proof-card > strong {
  color: #0f3f48;
  font-size: 1.8rem;
}

.fake-metric-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  padding: 16px;
  border-radius: 18px;
  background: #f3f8f8;
}

.fake-metric-row b {
  color: #0f3f48;
  font-size: 2.2rem;
  line-height: 1;
}

.fake-metric-row small {
  color: #647780;
  font-weight: 900;
}

.partner-value-section h2,
.partner-flow-section h2 {
  max-width: 760px;
  color: #0f3f48;
  font-size: clamp(1.8rem, 4vw, 3rem);
}

.partner-value-grid,
.partner-flow-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
  margin-top: 22px;
}

.partner-value-grid article,
.partner-flow-grid article {
  padding: 20px;
  border: 1px solid #dce7e9;
  border-radius: 20px;
  background: #fff;
  box-shadow: 0 16px 36px rgba(20, 55, 65, 0.06);
}

.partner-value-grid strong,
.partner-flow-grid strong {
  display: block;
  color: #0f3f48;
  font-size: 1.05rem;
}

.partner-value-grid p,
.partner-flow-grid p {
  color: #647780;
  line-height: 1.6;
}

.partner-flow-grid span {
  display: inline-grid;
  width: 36px;
  height: 36px;
  margin-bottom: 12px;
  place-items: center;
  border-radius: 999px;
  color: #fff;
  font-weight: 900;
  background: #11636c;
}

.partner-plan-table-wrap {
  overflow-x: auto;
  border: 1px solid #dce7e9;
  border-radius: 22px;
  background: #fff;
  box-shadow: 0 18px 48px rgba(20, 55, 65, 0.07);
}

.partner-plan-table {
  width: 100%;
  min-width: 760px;
  border-collapse: collapse;
}

.partner-plan-table th,
.partner-plan-table td {
  padding: 16px;
  border-bottom: 1px solid #edf3f4;
  text-align: left;
}

.partner-plan-table th {
  color: #0f3f48;
  background: #f3f8f8;
}

.partner-plan-table th:nth-child(3),
.partner-plan-table th:nth-child(4) {
  color: #fff;
  background: #11636c;
}

.partner-plan-table td:first-child {
  color: #0f3f48;
  font-weight: 900;
}

.partner-cta-band {
  margin: 40px 6vw 64px;
  padding: 34px;
  border-radius: 28px;
  color: #fff;
  background: linear-gradient(135deg, #0f3f48, #16717a);
}

.partner-apply-hero {
  padding: clamp(34px, 7vw, 76px) 6vw 28px;
  background:
    radial-gradient(circle at 84% 16%, rgba(224, 107, 45, 0.2), transparent 28%),
    linear-gradient(135deg, #edf8f7, #fff8ef);
}

.partner-apply-hero h1 {
  max-width: 880px;
  margin: 10px 0 18px;
  color: #0f3f48;
  font-size: clamp(2.5rem, 7vw, 5.6rem);
  line-height: 0.96;
  letter-spacing: -0.07em;
}

.partner-apply-hero p {
  max-width: 720px;
  color: #405a64;
  font-size: 1.08rem;
  line-height: 1.7;
}

.partner-apply-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 22px;
}

.partner-apply-badges span {
  border: 1px solid #bddbde;
  border-radius: 999px;
  padding: 10px 14px;
  color: #0f5963;
  background: #fff;
  font-weight: 900;
}

.partner-mobile-shell {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(280px, 0.65fr);
  gap: 22px;
  width: min(1180px, calc(100% - 32px));
  margin: 28px auto;
}

.partner-apply-card,
.partner-plan-mobile-card,
.partner-result-card {
  border: 1px solid #d6e6e8;
  border-radius: 26px;
  background: #fff;
  box-shadow: 0 20px 48px rgba(20, 55, 65, 0.08);
}

.partner-apply-card {
  padding: clamp(20px, 4vw, 34px);
}

.partner-apply-card h2 {
  margin: 6px 0 8px;
  color: #0f3f48;
  font-size: clamp(1.7rem, 5vw, 2.7rem);
}

.partner-apply-form {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  margin-top: 22px;
}

.partner-apply-form label {
  display: grid;
  gap: 7px;
  color: #16313e;
  font-weight: 900;
}

.partner-apply-form .wide {
  grid-column: 1 / -1;
}

.partner-apply-details {
  border: 1px solid #d6e6e8;
  border-radius: 20px;
  background: #fbfefe;
  overflow: hidden;
}

.partner-apply-details summary {
  cursor: pointer;
  padding: 17px 18px;
  color: #0f3f48;
  background: #f1faf9;
  font-weight: 1000;
  font-size: 1.08rem;
  list-style-position: inside;
}

.partner-apply-details[open] summary {
  border-bottom: 1px solid #d6e6e8;
}

.partner-apply-section-grid,
.partner-upload-zone {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  padding: 18px;
}

.partner-apply-section-grid label small {
  color: #0e7377;
  font-size: 0.78rem;
}

.partner-upload-zone {
  grid-template-columns: 1fr;
}

.partner-apply-form input,
.partner-apply-form select,
.partner-apply-form textarea {
  width: 100%;
  min-height: 52px;
  border: 1px solid #c8dce0;
  border-radius: 14px;
  padding: 13px 14px;
  color: #16313e;
  background: #fff;
  font: inherit;
}

.partner-apply-form textarea {
  min-height: 104px;
  resize: vertical;
}

.driver-inquiry-main {
  padding-bottom: 34px;
}

.driver-apply-hero {
  padding-bottom: 10px;
}

.driver-apply-card .partner-apply-section-grid {
  align-items: end;
}

.partner-consent-line {
  display: flex !important;
  grid-template-columns: none !important;
  align-items: flex-start;
  gap: 10px !important;
  border: 1px solid #d6e6e8;
  border-radius: 16px;
  padding: 14px;
  background: #f6fbfa;
  font-weight: 800 !important;
}

.partner-consent-line input {
  width: 20px !important;
  min-width: 20px;
  min-height: 20px !important;
  margin-top: 2px;
  padding: 0 !important;
}

.driver-result-card .mini-card-grid {
  margin: 16px 0;
}

.partner-upload-preview-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
  gap: 10px;
}

.partner-file-preview-card {
  position: relative;
  display: grid;
  gap: 6px;
  min-width: 0;
  border: 1px solid #d6e6e8;
  border-radius: 14px;
  padding: 8px;
  background: #fff;
}

.partner-file-thumb {
  display: grid;
  place-items: center;
  height: 76px;
  border-radius: 10px;
  color: #56707a;
  background: #edf4f5;
  font-weight: 900;
  overflow: hidden;
}

.partner-file-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.partner-file-preview-card strong,
.partner-file-preview-card span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.partner-file-preview-card strong {
  font-size: 0.82rem;
}

.partner-file-preview-card span {
  color: #59717a;
  font-size: 0.78rem;
}

.partner-file-preview-card small {
  position: absolute;
  top: 6px;
  right: 6px;
  min-width: 22px;
  border-radius: 999px;
  padding: 3px 6px;
  color: #fff;
  background: rgba(15, 63, 72, 0.88);
  text-align: center;
  font-weight: 900;
}

.partner-menu-builder,
.partner-link-list,
.partner-link-list-block {
  display: grid;
  gap: 10px;
  padding: 18px;
}

.partner-link-list-block {
  padding-top: 0;
}

.partner-menu-row,
.partner-link-row {
  display: grid;
  grid-template-columns: minmax(160px, 1.2fr) minmax(100px, 0.7fr) minmax(100px, 0.7fr) minmax(180px, 1.4fr) auto;
  gap: 8px;
  align-items: center;
}

.partner-link-row {
  grid-template-columns: minmax(0, 1fr) auto;
}

.partner-menu-row input,
.partner-link-row input {
  min-height: 46px;
}

.partner-row-remove {
  min-height: 46px;
  padding-inline: 14px;
  color: #9b2731;
  background: #fff5f5;
}

.partner-small-button {
  width: fit-content;
  margin: 0 18px 18px;
  min-height: 46px;
}

.partner-check-fieldset {
  margin: 0 18px 18px;
  border: 1px solid #d6e6e8;
  border-radius: 16px;
  padding: 14px;
}

.partner-check-fieldset legend {
  padding: 0 8px;
  color: #0f3f48;
  font-weight: 900;
}

.partner-check-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 8px;
}

.partner-check-grid label {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  border: 1px solid #d6e6e8;
  border-radius: 999px;
  padding: 10px 8px;
  background: #fff;
}

.partner-submit-button {
  grid-column: 1 / -1;
  min-height: 58px;
  font-size: 1.05rem;
}

.partner-plan-mobile-card {
  display: grid;
  align-content: start;
  gap: 14px;
  padding: 24px;
  background:
    radial-gradient(circle at 90% 12%, rgba(255, 213, 112, 0.28), transparent 30%),
    linear-gradient(135deg, #0f3f48, #126c73);
  color: #fff;
}

.partner-plan-mobile-card span {
  color: #d7fffb;
  font-weight: 900;
  letter-spacing: 0.08em;
}

.partner-plan-mobile-card strong {
  font-size: 1.6rem;
  line-height: 1.25;
}

.partner-plan-mobile-card ul {
  display: grid;
  gap: 10px;
  margin: 8px 0 0;
  padding-left: 20px;
}

.partner-plan-mobile-card li {
  line-height: 1.5;
}

.partner-inquiry-result {
  margin-top: 20px;
}

.partner-result-card {
  padding: 22px;
  background: #f4fbfa;
}

.partner-result-card span {
  color: #0f6b72;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.partner-result-card h3 {
  margin: 8px 0 10px;
  color: #0f3f48;
  font-size: 1.5rem;
}

.partner-result-card pre {
  overflow-x: auto;
  margin: 16px 0;
  padding: 16px;
  border: 1px solid #d6e6e8;
  border-radius: 16px;
  color: #16313e;
  background: #fff;
  font: 0.95rem/1.6 Arial, "Malgun Gothic", sans-serif;
  white-space: pre-wrap;
}

.partner-result-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.partner-result-actions a,
.partner-result-actions button {
  min-height: 50px;
}

.partner-simple-plan-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 20px;
}

.partner-simple-plan-grid article {
  padding: 22px;
  border: 1px solid #d6e6e8;
  border-radius: 22px;
  background: #fff;
  box-shadow: 0 16px 36px rgba(20, 55, 65, 0.06);
}

.partner-simple-plan-grid article.recommended {
  border-color: #0d7377;
  background: #effafa;
}

.partner-simple-plan-grid span {
  color: #317d82;
  font-weight: 900;
}

.partner-simple-plan-grid strong {
  display: block;
  margin: 8px 0;
  color: #0f3f48;
  font-size: 1.25rem;
}

.partner-cta-band h2,
.partner-cta-band p {
  max-width: 760px;
}

.partner-cta-band h2 {
  margin: 8px 0;
  font-size: clamp(1.8rem, 4vw, 3.2rem);
}

.partner-cta-band p {
  color: rgba(255, 255, 255, 0.82);
  line-height: 1.7;
}

.quick-chat-templates {
  display: grid;
  gap: 10px;
  margin-bottom: 18px;
}

.ask-ai-card,
.triptalk-card,
.triptalk-article {
  padding: 22px;
  border: 1px solid #dce7e9;
  border-radius: 16px;
  background: #fff;
}

.ask-ai-card {
  margin-bottom: 24px;
}

.triptalk-grid {
  display: grid;
  gap: 16px;
}

.triptalk-card {
  display: grid;
  gap: 8px;
}

.triptalk-card span {
  color: #70818a;
  font-size: 0.78rem;
  font-weight: 800;
}

.triptalk-card h2,
.triptalk-card p {
  margin: 0;
}

.triptalk-card p {
  color: #647780;
  line-height: 1.6;
}

.triptalk-main {
  max-width: 860px;
}

.triptalk-article {
  margin-top: 44px;
}

.home-hero {
  padding: 64px 0 28px;
}

.home-hero p:not(.eyebrow),
.saved-note {
  max-width: 720px;
  color: #647780;
  line-height: 1.7;
}

.saved-note {
  padding: 12px 14px;
  border-radius: 12px;
  background: #eff7f6;
}

.home-grid,
.popular-grid {
  display: grid;
  gap: 16px;
  margin: 24px 0;
}

.booking-first-hero {
  padding-bottom: 18px;
}

.booking-priority-section {
  padding-top: 20px;
}

.tour-priority-grid {
  display: grid;
  gap: 14px;
  margin: 22px 0;
}

.tour-priority-card {
  display: grid;
  gap: 9px;
  padding: 22px;
  border: 1px solid #dce7e9;
  border-radius: 18px;
  color: #16313e;
  text-decoration: none;
  background: #fff;
  box-shadow: 0 10px 26px rgba(20, 72, 82, 0.06);
}

.tour-priority-card.primary-tour {
  border-color: #8ac9c4;
  background: #eef9f8;
}

.tour-priority-card span {
  color: #3f8587;
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.1em;
}

.tour-priority-card h3,
.tour-priority-card p {
  margin: 0;
}

.tour-priority-card h3 {
  font-size: 1.25rem;
}

.tour-priority-card strong {
  font-size: 1.45rem;
}

.tour-priority-card p {
  color: #647780;
  line-height: 1.55;
}

.tour-priority-card b {
  display: inline-flex;
  justify-content: center;
  margin-top: 6px;
  padding: 11px 13px;
  border-radius: 10px;
  color: #fff;
  background: #11636c;
}

.home-drag-slider {
  -ms-overflow-style: none;
  overscroll-behavior-inline: contain;
  scroll-behavior: smooth;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  touch-action: pan-y pinch-zoom;
  user-select: none;
}

.home-drag-slider::-webkit-scrollbar {
  display: none;
}

.home-drag-slider.dragging {
  cursor: grabbing;
  scroll-behavior: auto;
  scroll-snap-type: none;
}

.home-drag-slider.dragging > * {
  pointer-events: none;
}

.home-drag-slider > * {
  -webkit-user-drag: none;
  scroll-snap-align: start;
  user-select: none;
}

.clean-home-hero {
  padding-bottom: 10px;
}

.clean-home-hero h1 {
  max-width: 980px;
}

.home-payment-strip {
  display: flex;
  align-items: center;
  gap: 14px;
  width: fit-content;
  max-width: 100%;
  margin-top: 22px;
  padding: 14px 18px;
  border: 1px solid rgba(20, 117, 125, 0.2);
  border-radius: 18px;
  background: rgba(235, 249, 247, 0.92);
  color: #113744;
  box-shadow: 0 14px 32px rgba(8, 55, 65, 0.08);
}

.home-payment-strip strong {
  flex: 0 0 auto;
  color: #0b7078;
  font-weight: 950;
}

.home-payment-strip span {
  color: #466371;
  font-size: 0.96rem;
  line-height: 1.45;
}

.home-main-entry-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  margin-top: 28px;
}

.home-main-entry-card {
  display: flex;
  min-height: 260px;
  flex-direction: column;
  justify-content: flex-end;
  gap: 12px;
  padding: clamp(22px, 4vw, 34px);
  border: 1px solid rgba(255, 255, 255, 0.34);
  border-radius: 28px;
  color: #fff;
  text-decoration: none;
  box-shadow: 0 22px 55px rgba(6, 36, 43, 0.26);
  overflow: hidden;
  position: relative;
}

.home-main-entry-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 18% 18%, rgba(255, 255, 255, 0.28), transparent 26%),
    linear-gradient(135deg, rgba(11, 98, 111, 0.96), rgba(12, 40, 54, 0.96));
  z-index: -1;
}

.home-main-entry-card.explore-entry::before {
  background:
    radial-gradient(circle at 78% 18%, rgba(255, 255, 255, 0.24), transparent 26%),
    linear-gradient(135deg, rgba(24, 133, 105, 0.96), rgba(14, 61, 75, 0.96));
}

.home-main-entry-card span {
  width: fit-content;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.18);
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.12em;
}

.home-main-entry-card h2 {
  margin: 0;
  color: #fff;
  font-size: clamp(2rem, 5vw, 3.4rem);
  line-height: 1;
}

.home-main-entry-card p {
  max-width: 560px;
  margin: 0;
  color: rgba(255, 255, 255, 0.86);
  font-size: 1rem;
}

.home-main-entry-card strong {
  width: fit-content;
  margin-top: 8px;
  padding: 12px 18px;
  border-radius: 999px;
  background: #fff;
  color: #0f3f49;
}

.section-lead {
  max-width: 760px;
  margin: -4px 0 22px;
  color: var(--muted);
  font-size: 1rem;
  line-height: 1.65;
}

.airport-vehicle-choice-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.airport-vehicle-choice {
  display: flex;
  min-height: 100%;
  flex-direction: column;
  gap: 16px;
  padding: clamp(20px, 3vw, 28px);
  border: 1px solid var(--line);
  border-radius: 24px;
  background: #fff;
  box-shadow: 0 18px 48px rgba(16, 49, 59, 0.08);
}

.airport-vehicle-choice.van-choice {
  border-color: rgba(18, 112, 120, 0.32);
  background: linear-gradient(180deg, #effdfb, #fff);
}

.choice-badge {
  width: fit-content;
  padding: 8px 12px;
  border-radius: 999px;
  background: #ecf5f4;
  color: #0d6d73;
  font-size: 0.78rem;
  font-weight: 950;
  letter-spacing: 0.1em;
}

.airport-vehicle-choice h3 {
  margin: 0;
  font-size: clamp(1.4rem, 3vw, 2rem);
}

.airport-vehicle-choice p {
  margin: 0;
  color: var(--muted);
  line-height: 1.65;
}

.estimate-box {
  display: grid;
  gap: 6px;
  padding: 16px;
  border-radius: 18px;
  background: #f4f8f8;
}

.estimate-box.highlight {
  background: #123f49;
  color: #fff;
}

.estimate-box strong {
  font-size: 0.88rem;
  color: inherit;
  opacity: 0.86;
}

.estimate-box span {
  color: #0b7078;
  font-size: 1.45rem;
  font-weight: 950;
}

.estimate-box.highlight span {
  color: #fff;
}

.estimate-box small {
  color: inherit;
  opacity: 0.72;
}

.polite-guide-list {
  display: grid;
  gap: 8px;
  margin: 0;
  padding-left: 18px;
  color: #496877;
}

.strong-taxi-link {
  font-weight: 900;
}

.place-actions .strong-taxi-link {
  min-height: 48px;
  padding: 13px 16px;
  border: 0;
  color: #fff;
  background: #0b7078;
  box-shadow: 0 12px 26px rgba(8, 78, 86, 0.18);
}

.place-actions .strong-taxi-link + .strong-taxi-link {
  color: #2d2b1a;
  background: #f9df3b;
}

.transfer-type-card.active {
  outline: 3px solid rgba(18, 112, 120, 0.22);
  outline-offset: 4px;
}

.tour-addon-panel {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 18px;
  align-items: center;
  padding: clamp(18px, 3vw, 24px);
  border: 1px solid rgba(18, 112, 120, 0.2);
  border-radius: 22px;
  background: linear-gradient(135deg, #f0fbfa, #fff);
}

.tour-addon-panel h2,
.tour-addon-panel p {
  margin: 0;
}

.tour-addon-panel p:not(.eyebrow) {
  color: var(--muted);
  line-height: 1.6;
}

.tour-addon-toggle {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  width: fit-content;
  padding: 13px 16px;
  border: 1px solid rgba(18, 112, 120, 0.28);
  border-radius: 999px;
  background: #fff;
  color: #0d5e66;
  font-weight: 950;
  cursor: pointer;
  white-space: nowrap;
}

.tour-addon-toggle input {
  width: 18px;
  height: 18px;
  accent-color: #0b7078;
}

.taxi-tour-menu-section {
  overflow: hidden;
}

.taxi-tour-tabs {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 12px;
  margin: 22px 0 24px;
}

.taxi-tour-tabs button {
  min-height: 48px;
  padding: 12px 16px;
  border: 1px solid rgba(17, 99, 108, 0.18);
  border-radius: 24px;
  color: #315765;
  background: #fff;
  font-weight: 950;
  cursor: pointer;
  box-shadow: 0 10px 24px rgba(8, 55, 65, 0.06);
}

.taxi-tour-tabs button.active {
  color: #fff;
  border-color: #0b7078;
  background: #0b7078;
  box-shadow: 0 14px 30px rgba(10, 91, 99, 0.18);
}

.taxi-menu-image-card {
  position: relative;
  overflow: hidden;
  display: grid;
  align-content: end;
  gap: 7px;
  min-height: 190px;
  text-align: left;
  color: #fff !important;
  isolation: isolate;
}

.taxi-menu-image-card::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -2;
  background:
    radial-gradient(circle at 28% 18%, rgba(255, 255, 255, 0.28), transparent 28%),
    linear-gradient(135deg, #0f767d, #082b36);
}

.taxi-menu-image-card::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background: linear-gradient(180deg, rgba(3, 28, 35, 0.1), rgba(3, 28, 35, 0.84));
}

.taxi-menu-image-card.first-day::before {
  background:
    radial-gradient(circle at 68% 22%, rgba(255, 216, 93, 0.72), transparent 28%),
    linear-gradient(135deg, #116f7b, #23375f 58%, #d97b3c);
}

.taxi-menu-image-card.private::before {
  background:
    radial-gradient(circle at 72% 24%, rgba(165, 230, 255, 0.62), transparent 26%),
    linear-gradient(135deg, #082b36, #0f5962 52%, #133b57);
}

.taxi-menu-image-card.join::before {
  background:
    radial-gradient(circle at 26% 20%, rgba(255, 255, 255, 0.34), transparent 28%),
    linear-gradient(135deg, #145d64, #0b3440 55%, #568b72);
}

.taxi-menu-image-card.last-day::before {
  background:
    radial-gradient(circle at 72% 24%, rgba(255, 223, 120, 0.78), transparent 27%),
    linear-gradient(135deg, #103445, #614778 54%, #c46a45);
}

.taxi-menu-image-card span {
  width: fit-content;
  padding: 6px 9px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.18);
  font-size: 0.68rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.taxi-menu-image-card strong {
  font-size: clamp(1.05rem, 2vw, 1.45rem);
  line-height: 1.08;
}

.taxi-menu-image-card small {
  color: rgba(255, 255, 255, 0.84);
  font-size: 0.84rem;
  line-height: 1.35;
}

.taxi-tour-panel {
  display: grid;
  gap: 22px;
}

.taxi-tour-panel[hidden] {
  display: none;
}

.taxi-panel-copy {
  max-width: 840px;
  padding: clamp(18px, 3vw, 28px);
  border-radius: 24px;
  background:
    radial-gradient(circle at 84% 20%, rgba(32, 163, 158, 0.16), transparent 28%),
    linear-gradient(135deg, #f1fbfa, #fff);
}

.taxi-panel-copy h3 {
  margin: 8px 0 12px;
  color: #12313b;
  font-size: clamp(1.75rem, 4vw, 3.1rem);
  line-height: 1.04;
  letter-spacing: -0.06em;
}

.taxi-panel-copy p:not(.eyebrow) {
  margin: 0;
  color: #526b76;
  line-height: 1.72;
}

.taxi-panel-copy.last-day-hook {
  background:
    radial-gradient(circle at 88% 16%, rgba(255, 216, 77, 0.3), transparent 26%),
    linear-gradient(135deg, #fff8df, #fff);
}

.taxi-submenu-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.taxi-submenu-grid.three {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.taxi-submenu-card {
  position: relative;
  overflow: hidden;
  display: grid;
  align-content: end;
  min-height: 300px;
  gap: 10px;
  padding: 24px;
  border: 1px solid rgba(17, 99, 108, 0.15);
  border-radius: 28px;
  color: #16313e;
  text-decoration: none;
  background:
    radial-gradient(circle at 26% 18%, rgba(255, 255, 255, 0.88), transparent 0 18%, transparent 42%),
    linear-gradient(135deg, #ffffff, #eef8f7);
  box-shadow: 0 18px 44px rgba(8, 55, 65, 0.1);
}

.taxi-submenu-card.primary {
  color: #fff;
  border-color: rgba(11, 112, 120, 0.35);
  background:
    radial-gradient(circle at 26% 18%, rgba(255, 255, 255, 0.28), transparent 0 18%, transparent 42%),
    linear-gradient(135deg, #0b7078, #0a2b36);
}

.taxi-submenu-card span {
  width: fit-content;
  padding: 7px 10px;
  border-radius: 999px;
  color: #0b7078;
  background: rgba(11, 112, 120, 0.1);
  font-size: 0.72rem;
  font-weight: 950;
  letter-spacing: 0.1em;
}

.taxi-submenu-card.primary span {
  color: #fff;
  background: rgba(255, 255, 255, 0.16);
}

.taxi-submenu-card strong {
  font-size: clamp(1.45rem, 3vw, 2.2rem);
  line-height: 1.05;
  letter-spacing: -0.05em;
}

.taxi-submenu-card p {
  margin: 0;
  color: #59717b;
  line-height: 1.62;
}

.taxi-submenu-card.primary p {
  color: rgba(255, 255, 255, 0.82);
}

.taxi-submenu-card b {
  width: fit-content;
  margin-top: 8px;
  padding: 12px 16px;
  border-radius: 999px;
  color: #fff;
  background: #0b7078;
  font-size: 0.94rem;
}

.taxi-submenu-card.primary b {
  color: #0b3f48;
  background: #fff;
}

.taxi-inline-step-card {
  margin-top: 24px;
  padding: clamp(20px, 3vw, 32px);
  border: 1px solid rgba(17, 99, 108, 0.14);
  border-radius: 28px;
  background: #ffffff;
  box-shadow: 0 18px 42px rgba(8, 55, 65, 0.08);
}

.taxi-inline-step-card h3 {
  margin: 8px 0 12px;
  color: #12313b;
  font-size: clamp(1.65rem, 4vw, 2.7rem);
  line-height: 1.05;
  letter-spacing: -0.055em;
}

.taxi-inline-step-card > p:not(.eyebrow) {
  max-width: 820px;
  color: #526b76;
  line-height: 1.72;
}

.taxi-inline-vehicle-grid {
  margin-top: 22px;
}

.taxi-inline-form-card {
  padding-bottom: 12px;
}

.airport-van-inline-frame {
  display: block;
  width: 100%;
  min-height: 1180px;
  margin-top: 18px;
  border: 1px solid rgba(17, 99, 108, 0.16);
  border-radius: 24px;
  background: #f8fbfb;
}

.taxi-menu-inline-frame {
  min-height: 2200px;
}

body.embedded-inquiry-page {
  overflow-x: hidden;
  background: transparent;
}

body.embedded-inquiry-page .site-header,
body.embedded-inquiry-page .inquiry-intro,
body.embedded-inquiry-page .corporate-footer {
  display: none !important;
}

body.embedded-inquiry-page .inquiry-main {
  width: 100%;
  max-width: none;
  padding: 0;
}

body.embedded-inquiry-page .inquiry-card {
  margin: 0;
  padding: clamp(16px, 2vw, 24px);
  border: 0;
  box-shadow: none;
  background: #ffffff;
}

body.embedded-inquiry-page .selected-tour {
  display: none !important;
}

body.embedded-inquiry-page .simplified-first-day-card {
  border-radius: 0;
}

.taxi-submenu-card:not(.primary) b {
  color: #ffffff;
}

.hot-spots-menu-section {
  padding-top: 32px;
}

.hot-spot-tabs {
  margin-top: 20px;
}

.hot-spot-category-section {
  margin: 46px 0 0;
}

.hot-spot-favorite-help {
  margin: -8px 0 18px;
  color: #5f7480;
  font-weight: 800;
}

.hot-spot-slider {
  gap: 18px;
  padding-bottom: 8px;
}

.hot-spot-card {
  position: relative;
  flex: 0 0 min(280px, 76vw);
  overflow: hidden;
  border: 1px solid rgba(15, 111, 116, 0.16);
  border-radius: 24px;
  background: #ffffff;
  box-shadow: 0 18px 38px rgba(9, 54, 58, 0.1);
  scroll-snap-align: start;
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}

.hot-spot-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 24px 44px rgba(9, 54, 58, 0.16);
}

.hot-spot-card-link {
  display: block;
  color: inherit;
  text-decoration: none;
}

.hot-spot-card-art {
  min-height: 0;
  aspect-ratio: 1 / 1;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 8px;
  padding: 20px;
  color: #ffffff;
  background:
    linear-gradient(180deg, rgba(5, 27, 33, 0.08), rgba(5, 27, 33, 0.88)),
    var(--hot-spot-image, radial-gradient(circle at 32% 22%, rgba(255, 255, 255, 0.28), transparent 28%), linear-gradient(135deg, #0f6f74, #09232c));
  background-size: cover;
  background-position: center;
}

.hot-spot-card-art span {
  width: fit-content;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(6, 38, 45, 0.68);
  font-size: 0.76rem;
  font-weight: 900;
  letter-spacing: 0.02em;
}

.hot-spot-card-art strong {
  max-width: 82%;
  font-size: clamp(1.25rem, 3vw, 1.85rem);
  line-height: 1.02;
  text-shadow: 0 3px 14px rgba(0, 0, 0, 0.34);
}

.hot-spot-card-body {
  padding: 12px 14px 14px;
}

.hot-spot-card-body h3 {
  margin: 0 0 8px;
  font-size: 1.2rem;
  line-height: 1.15;
}

.hot-spot-card-body p {
  margin: 0;
  color: #5f7480;
  line-height: 1.55;
}

.hot-spot-card-body small {
  display: block;
  margin-top: 0;
  color: #58707a;
  font-size: 0.86rem;
  font-weight: 850;
  line-height: 1.45;
}

.hot-spot-card-body .open-status {
  display: inline-flex;
  align-items: center;
  padding: 3px 7px;
  border-radius: 999px;
  background: #eef7f6;
  color: #0f6f74;
  font-size: 0.78rem;
}

.hot-spot-card-body .open-status.closed {
  background: #fff1ea;
  color: #b6532f;
}

.hot-spot-card-body .open-status.open,
.hot-spot-card-body .open-status.closing-soon {
  background: #e8f8ee;
  color: #0a7a4e;
}

.explore-place-modern-card {
  min-height: 0;
}

.hot-spot-heart-button {
  position: absolute;
  top: 14px;
  right: 14px;
  width: 44px;
  height: 44px;
  border: 1px solid rgba(255, 255, 255, 0.78);
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.86);
  color: #0f6f74;
  font-size: 1.3rem;
  font-weight: 900;
  cursor: pointer;
  box-shadow: 0 12px 22px rgba(8, 40, 45, 0.2);
}

.hot-spot-heart-button.is-saved {
  border-color: #ff6b5e;
  background: #ff6b5e;
  color: #ffffff;
}

.hot-spot-save-toast {
  position: fixed;
  left: 50%;
  bottom: 24px;
  z-index: 60;
  transform: translateX(-50%);
  padding: 12px 18px;
  border-radius: 999px;
  background: #082f36;
  color: #ffffff;
  font-weight: 900;
  box-shadow: 0 18px 42px rgba(5, 29, 34, 0.24);
}

.hot-spot-save-toast[hidden] {
  display: none;
}

@media (max-width: 900px) {
  .taxi-submenu-grid,
  .taxi-submenu-grid.three {
    grid-template-columns: 1fr;
  }

  .taxi-submenu-card {
    min-height: 240px;
  }
}

@media (max-width: 640px) {
  .landing-menu-card-grid.home-service-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 10px;
  }

  .landing-menu-card-grid.home-service-grid .landing-menu-card {
    min-height: 148px;
    padding: 14px 12px;
    border-radius: 22px;
  }

  .landing-menu-card-grid.home-service-grid .landing-menu-card::after {
    top: 12px;
    right: 12px;
    width: 34px;
    height: 34px;
    font-size: 0.95rem;
  }

  .landing-menu-card-grid.home-service-grid .landing-menu-card span {
    font-size: 1.5rem;
  }

  .landing-menu-card-grid.home-service-grid .landing-menu-card strong {
    max-width: 92%;
    font-size: 1rem;
    line-height: 1.08;
  }

  .landing-menu-card-grid.home-service-grid .landing-menu-card small {
    display: none;
  }

  .traveler-explore-section {
    padding: 24px 16px;
  }

  .traveler-explore-section .landing-section-heading h2 {
    font-size: clamp(1.75rem, 8vw, 2.35rem);
  }

  .traveler-explore-section .landing-section-heading p:not(.eyebrow) {
    font-size: 0.95rem;
    line-height: 1.5;
  }

  .home-explore-image-cta {
    min-height: 170px;
    padding: 18px;
    border-radius: 22px;
  }

  .home-explore-image-cta strong {
    font-size: clamp(1.55rem, 7vw, 2.15rem);
  }

  .home-explore-image-cta small {
    font-size: 0.9rem;
  }

  .landing-only-header {
    padding-inline: 14px;
  }

  .landing-hero-actions {
    display: grid;
    grid-template-columns: 1fr;
    width: min(360px, 100%);
    margin-inline: auto;
  }

  .landing-hero-actions a {
    width: 100%;
  }

  .home-tight-section {
    padding: 36px 16px;
  }

  .home-service-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
  }

  .home-service-grid .landing-menu-card {
    min-height: 172px;
    padding: 16px 14px;
  }

  .home-service-grid .landing-menu-card span {
    font-size: 1.6rem;
  }

  .home-service-grid .landing-menu-card strong {
    font-size: 1.02rem;
    line-height: 1.18;
  }

  .home-service-grid .landing-menu-card small {
    font-size: 0.78rem;
    line-height: 1.35;
  }

  .home-pay-cancel-grid {
    grid-template-columns: 1fr;
  }

  .home-pay-cancel-grid article {
    min-height: 0;
    padding: 22px;
    border-radius: 20px;
  }

  .home-pay-cancel-grid h2 {
    font-size: clamp(2rem, 10vw, 2.8rem);
  }

  .compact-place-card .premium-place-art {
    min-height: 260px;
  }

  .taxi-tour-tabs {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    margin: 16px 0 20px;
    padding: 0;
    overflow: visible;
  }

  .taxi-menu-image-card {
    min-height: 168px;
    padding: 14px;
  }

  .taxi-menu-image-card:last-child {
    grid-column: 1 / -1;
  }
}

.home-wide-slider {
  display: flex;
  gap: 16px;
  overflow-x: auto;
  padding: 4px 2px 20px;
  cursor: grab;
}

.home-wide-slider > * {
  flex: 0 0 min(330px, 82vw);
  min-height: 310px;
}

.home-tight-section {
  max-width: 1180px;
  margin: 0 auto;
  padding: clamp(44px, 7vw, 82px) clamp(18px, 4vw, 34px);
}

.landing-hero-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px;
  margin-top: 22px;
}

.compact-promise-grid {
  max-width: 720px;
  margin-inline: auto;
}

.home-service-grid {
  grid-template-columns: repeat(6, minmax(0, 1fr));
}

@media (max-width: 1100px) {
  .home-service-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.traveler-explore-section {
  gap: 16px;
}

.traveler-explore-section .landing-section-heading {
  max-width: 720px;
}

.traveler-explore-section .landing-section-heading p:not(.eyebrow) {
  max-width: 620px;
}

.home-explore-image-cta {
  position: relative;
  overflow: hidden;
  display: grid;
  min-height: 220px;
  align-content: end;
  gap: 8px;
  padding: 22px;
  border-radius: 26px;
  color: #ffffff;
  text-decoration: none;
  background:
    linear-gradient(180deg, rgba(5, 27, 33, 0.02), rgba(5, 27, 33, 0.86)),
    radial-gradient(circle at 18% 12%, rgba(255, 255, 255, 0.28), transparent 26%),
    linear-gradient(135deg, #0d7a7d, #102f3a 62%, #061f27);
  box-shadow: 0 20px 48px rgba(8, 55, 65, 0.16);
}

.home-explore-image-cta::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 82% 26%, rgba(255, 218, 118, 0.42), transparent 0 15%, transparent 28%),
    radial-gradient(circle at 18% 72%, rgba(127, 220, 214, 0.32), transparent 0 18%, transparent 32%);
  opacity: 0.92;
}

.home-explore-image-cta::after {
  content: "→";
  position: absolute;
  top: 18px;
  right: 18px;
  width: 46px;
  height: 46px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  color: #0a2b36;
  background: #ffffff;
  font-weight: 950;
}

.home-explore-image-cta > * {
  position: relative;
  z-index: 1;
}

.home-explore-image-cta span {
  width: fit-content;
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.18);
  font-size: 0.82rem;
  font-weight: 950;
}

.home-explore-image-cta strong {
  max-width: 520px;
  font-size: clamp(1.75rem, 5vw, 3rem);
  line-height: 1.02;
  letter-spacing: -0.055em;
}

.home-explore-image-cta small {
  max-width: 520px;
  color: rgba(255, 255, 255, 0.86);
  font-size: 1rem;
  font-weight: 800;
}

.home-pay-cancel-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.home-pay-cancel-grid article {
  min-height: 260px;
  padding: clamp(22px, 4vw, 34px);
  border: 1px solid #dce8e8;
  border-radius: 26px;
  background:
    radial-gradient(circle at 92% 18%, rgba(15, 122, 130, 0.12), transparent 32%),
    #ffffff;
  box-shadow: 0 20px 48px rgba(8, 44, 54, 0.08);
}

.home-pay-cancel-grid h2 {
  margin: 10px 0 12px;
  font-size: clamp(2rem, 4vw, 3.45rem);
  line-height: 0.98;
  letter-spacing: -0.06em;
}

.home-pay-cancel-grid p {
  max-width: 560px;
  color: #536e78;
  font-size: 1.02rem;
  line-height: 1.7;
}

.compact-place-card {
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}

.compact-place-card .premium-place-art {
  position: relative;
  display: grid;
  align-content: end;
  min-height: 310px;
  padding: 18px;
  overflow: hidden;
  border-radius: 22px;
  color: #ffffff;
  background:
    linear-gradient(180deg, rgba(0, 0, 0, 0.03), rgba(0, 0, 0, 0.72)),
    var(--place-image, linear-gradient(135deg, #0e6169, #112f3e));
  background-size: cover;
  background-position: center;
}

.compact-place-card .premium-place-art::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 26% 20%, rgba(255, 255, 255, 0.22), transparent 26%),
    linear-gradient(180deg, transparent 30%, rgba(4, 28, 35, 0.72));
}

.compact-place-card .premium-place-art > * {
  position: relative;
  z-index: 1;
}

.compact-place-card strong {
  display: block;
  color: #ffffff;
  font-size: 1.34rem;
  line-height: 1.08;
  letter-spacing: -0.035em;
  text-decoration: none;
}

.compact-place-card small {
  display: block;
  margin-top: 7px;
  color: rgba(255, 255, 255, 0.82);
  font-weight: 800;
}

.home-card-heart {
  position: absolute;
  top: 12px;
  right: 12px;
  z-index: 2;
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border: 1px solid rgba(255, 255, 255, 0.44);
  border-radius: 999px;
  color: #ffffff;
  background: rgba(5, 35, 44, 0.48);
  backdrop-filter: blur(10px);
  font-size: 1.34rem;
  font-weight: 900;
}

.landing-partner-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: 14px;
  color: #5d747c;
  font-weight: 900;
}

.corporate-footer {
  background:
    radial-gradient(circle at 88% 20%, rgba(17, 99, 108, 0.12), transparent 28%),
    linear-gradient(135deg, #f6fbfb, #e9f4f3);
}

.corporate-footer-inner {
  align-items: flex-start;
}

.footer-brand small {
  display: block;
  margin-top: 14px;
  color: #70818a;
  line-height: 1.5;
}

.footer-columns {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 18px;
  min-width: min(680px, 100%);
}

.footer-columns nav {
  display: grid;
  justify-content: stretch;
  gap: 8px;
}

.footer-columns b {
  color: #16313e;
  font-size: 0.92rem;
}

.footer-columns a,
.footer-columns span {
  display: block;
  min-height: auto;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: #526b74;
  font-size: 0.9rem;
  font-weight: 700;
  line-height: 1.45;
}

.footer-columns a:first-child {
  color: #526b74;
  background: transparent;
  border: 0;
}

.footer-emergency-inline {
  display: grid;
  gap: 8px;
  margin-top: 10px;
  padding-top: 12px;
  border-top: 1px solid rgba(17, 99, 108, 0.14);
}

.footer-emergency-inline strong {
  color: #16313e;
  font-size: 0.86rem;
  font-weight: 900;
}

.footer-emergency-icons {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.footer-columns .footer-emergency-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  padding: 0;
  border: 1px solid rgba(17, 99, 108, 0.18);
  border-radius: 50%;
  box-shadow: 0 8px 18px rgba(5, 35, 44, 0.08);
  font-size: 0.72rem;
  font-weight: 1000;
  line-height: 1;
}

.footer-columns .footer-emergency-icon.line {
  color: #06a44f;
  background: #e9fff2;
}

.footer-columns .footer-emergency-icon.whatsapp {
  color: #0b8f4d;
  background: #e8fff1;
}

.footer-columns .footer-emergency-icon.phone {
  color: #7a3b00;
  background: #fff6dd;
  font-size: 1.05rem;
}

body.explore-baemin-page {
  background:
    radial-gradient(circle at 12% 8%, rgba(42, 193, 188, 0.16), transparent 28%),
    linear-gradient(180deg, #f6fffe 0%, #fbfbf7 42%, #ffffff 100%);
}

.explore-baemin-page .site-header {
  position: sticky;
  top: 0;
  z-index: 20;
  background: rgba(255, 255, 255, 0.92);
  backdrop-filter: blur(14px);
}

.explore-baemin-hero,
.explore-home-block {
  width: min(960px, calc(100% - 32px));
  margin: 18px auto;
}

.explore-baemin-hero {
  padding: 24px 18px;
  border: 1px solid rgba(42, 193, 188, 0.22);
  border-radius: 26px;
  background:
    radial-gradient(circle at 88% 12%, rgba(255, 225, 82, 0.38), transparent 26%),
    linear-gradient(135deg, #ffffff, #eafffd);
  box-shadow: 0 20px 44px rgba(17, 99, 108, 0.1);
}

.explore-baemin-hero h1 {
  margin: 8px 0 10px;
  color: #102f3a;
  font-size: clamp(2.1rem, 8vw, 4.4rem);
  letter-spacing: -0.07em;
  line-height: 0.98;
}

.explore-baemin-hero p:not(.eyebrow) {
  max-width: 620px;
  margin: 0;
  color: #536d73;
  font-weight: 700;
  line-height: 1.55;
}

.baemin-search-panel {
  margin: 18px 0 0;
}

.baemin-search-panel input {
  width: min(620px, 100%);
  border-color: rgba(42, 193, 188, 0.32);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.7);
}

.explore-home-block {
  padding: 18px;
  border: 1px solid rgba(17, 99, 108, 0.12);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.78);
  box-shadow: 0 16px 34px rgba(20, 60, 64, 0.07);
}

.explore-block-heading {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}

.explore-block-heading h2 {
  margin: 0;
  color: #102f3a;
  font-size: clamp(1.25rem, 4vw, 2rem);
  letter-spacing: -0.05em;
}

.explore-icon-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
}

.explore-icon-grid button {
  display: grid;
  place-items: center;
  min-height: 88px;
  padding: 10px 4px;
  border: 1px solid rgba(42, 193, 188, 0.22);
  border-radius: 20px;
  background: #ffffff;
  color: #173b43;
  box-shadow: 0 10px 22px rgba(19, 83, 91, 0.07);
  cursor: pointer;
}

.explore-icon-grid button span {
  display: block;
  font-size: 1.55rem;
}

.explore-icon-grid button strong {
  display: block;
  margin-top: 4px;
  font-size: 0.78rem;
  font-weight: 950;
}

.explore-icon-grid button.active {
  border-color: #2ac1bc;
  background: #2ac1bc;
  color: #ffffff;
}

.explore-chip-row {
  width: 100%;
  padding: 0 0 2px;
}

.explore-chip-row button {
  border-color: rgba(42, 193, 188, 0.24);
  background: #fff;
  color: #234a52;
}

.explore-chip-row button.active {
  background: #102f3a;
  color: #ffffff;
}

.baemin-location-note {
  width: min(960px, calc(100% - 32px));
  margin: 14px auto 4px;
  border-radius: 18px;
  background: #eafffd;
  color: #30666d;
}

.baemin-result-list {
  width: min(960px, calc(100% - 32px));
}

.baemin-place-card {
  overflow: hidden;
  border-radius: 24px;
  background: #fff;
  box-shadow: 0 18px 38px rgba(15, 55, 62, 0.1);
}

.baemin-place-card .explore-list-photo {
  min-height: 220px;
}

.baemin-place-card .explore-list-mini-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 14px 14px;
}

.baemin-place-card .explore-list-mini-meta span {
  color: #0c716f;
  font-weight: 900;
}

@media (max-width: 640px) {
  .explore-baemin-page .site-header {
    align-items: center;
    gap: 10px;
    padding: 12px 14px;
  }

  .explore-baemin-page .site-header nav {
    justify-content: flex-end;
    gap: 10px;
    overflow-x: auto;
    white-space: nowrap;
  }

  .explore-baemin-page .site-header nav a {
    font-size: 0.78rem;
  }

  .explore-baemin-hero,
  .explore-home-block,
  .baemin-location-note,
  .baemin-result-list {
    width: calc(100% - 24px);
  }

  .explore-baemin-hero {
    margin-top: 12px;
    padding: 20px 14px;
    border-radius: 22px;
  }

  .explore-baemin-hero h1 {
    font-size: clamp(2.4rem, 13vw, 3.35rem);
  }

  .baemin-search-panel {
    display: grid;
    gap: 8px;
  }

  .baemin-search-panel input,
  .baemin-search-panel button {
    width: 100%;
  }

  .explore-home-block {
    padding: 14px;
    border-radius: 20px;
  }

  .explore-block-heading {
    display: grid;
    gap: 3px;
  }

  .explore-icon-grid {
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 7px;
  }

  .explore-icon-grid button {
    min-height: 74px;
    border-radius: 16px;
  }

  .explore-icon-grid button span {
    font-size: 1.34rem;
  }

  .explore-icon-grid button strong {
    font-size: 0.62rem;
  }

  .baemin-place-card .explore-list-photo {
    min-height: 170px;
  }

  .baemin-place-card .explore-list-overlay .explore-list-title-row h2 {
    font-size: 1.08rem;
  }
}

body.explore-baemin-page .customer-simple-header {
  display: flex !important;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 16px;
}

body.explore-baemin-page .customer-simple-header .logo {
  flex: 0 0 auto;
}

body.explore-baemin-page .tripbusan-language-switcher {
  position: relative;
  z-index: 55;
  margin-left: auto;
}

body.explore-baemin-page .tripbusan-language-button {
  display: inline-flex;
  min-width: 58px;
  height: 38px;
  align-items: center;
  justify-content: center;
  gap: 5px;
  padding: 0 12px;
  border: 1px solid rgba(16, 93, 100, 0.16);
  border-radius: 999px;
  color: #0c4f58;
  background: rgba(255, 255, 255, 0.96);
  font-weight: 950;
  box-shadow: 0 10px 24px rgba(18, 94, 100, 0.12);
}

body.explore-baemin-page .tripbusan-language-menu {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  min-width: 178px;
  padding: 8px;
  border: 1px solid rgba(16, 93, 100, 0.16);
  border-radius: 18px;
  background: #ffffff;
  box-shadow: 0 18px 42px rgba(8, 55, 65, 0.16);
}

body.explore-baemin-page .tripbusan-language-menu button {
  display: block;
  width: 100%;
  padding: 10px 12px;
  border: 0;
  border-radius: 12px;
  color: #173b43;
  background: transparent;
  font-weight: 850;
  text-align: left;
}

body.explore-baemin-page .tripbusan-language-menu button.active,
body.explore-baemin-page .tripbusan-language-menu button:hover {
  background: #e8fbf6;
  color: #007d80;
}

body.explore-baemin-page .explore-category-block .explore-block-heading {
  display: grid;
  grid-template-columns: 1fr;
  align-items: start;
  justify-content: start;
  gap: 8px;
}

body.explore-baemin-page .explore-category-block .explore-block-heading > p:last-child {
  max-width: 540px;
  margin: 0;
  color: #4f6870;
  font-weight: 750;
  line-height: 1.38;
}

body.explore-baemin-page .explore-main-title {
  margin: 2px 0 4px;
  color: #102f3a;
  font-size: clamp(2.55rem, 9vw, 5.2rem);
  line-height: 0.92;
  letter-spacing: -0.085em;
}

body.explore-baemin-page .explore-main-title span {
  display: block;
  white-space: nowrap;
}

body.explore-baemin-page .explore-category-block .explore-icon-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

body.explore-baemin-page .explore-category-block .explore-icon-grid button {
  min-height: 96px;
  padding: 10px 4px;
  border-radius: 22px;
}

body.explore-baemin-page .explore-category-block .explore-icon-grid button span {
  margin-bottom: 6px;
  font-size: clamp(1.55rem, 5.8vw, 2.15rem);
}

body.explore-baemin-page .explore-category-block .explore-icon-grid button strong {
  font-size: clamp(0.66rem, 2.4vw, 0.86rem);
  line-height: 1.1;
}

body.explore-baemin-page .explore-category-block .explore-icon-grid button.featured-category {
  border-color: rgba(255, 179, 48, 0.75);
  background: linear-gradient(145deg, #fff6d9, #ffffff 62%);
  box-shadow: 0 14px 30px rgba(255, 179, 48, 0.18);
}

body.explore-baemin-page .explore-category-block .explore-icon-grid button.featured-category.active {
  color: #10323a;
  background: linear-gradient(145deg, #ffe18a, #fff7d8);
}

body.explore-baemin-page .daily-shorts-block .slider-arrow-bar,
body.explore-baemin-page .baemin-location-note {
  display: none !important;
}

.partner-center-entry {
  width: min(960px, calc(100% - 32px));
  margin: 28px auto 10px;
  padding: 16px;
  border: 1px dashed rgba(16, 93, 100, 0.22);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.82);
  box-shadow: 0 14px 30px rgba(20, 60, 64, 0.07);
}

.partner-center-entry-title {
  display: inline-flex;
  color: #0b7176;
  font-size: 1rem;
  font-weight: 950;
  text-decoration: none;
}

.partner-center-entry p {
  margin: 6px 0 12px;
  color: #5d7177;
  font-size: 0.9rem;
  line-height: 1.45;
}

.partner-center-entry-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.partner-center-entry-actions a,
.partner-login-join-box a {
  display: inline-flex;
  min-height: 42px;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  color: #ffffff;
  background: #087b7e;
  font-weight: 950;
  text-decoration: none;
}

.partner-center-entry-actions a:last-child,
.partner-login-join-box a {
  color: #0c555b;
  background: #e8fbf6;
  border: 1px solid rgba(8, 123, 126, 0.16);
}

.partner-login-join-box {
  display: grid;
  gap: 8px;
  margin-top: 12px;
  padding: 12px;
  border: 1px solid rgba(8, 123, 126, 0.14);
  border-radius: 16px;
  background: #f5fffc;
  text-align: center;
}

.partner-login-join-box span {
  color: #5d7177;
  font-size: 0.9rem;
  font-weight: 800;
}

.partner-login-card {
  width: min(420px, calc(100% - 28px));
  margin: min(16vh, 96px) auto 0;
}

.partner-login-card h1 {
  margin: 0 0 18px;
  color: #082f39;
  font-size: 1.8rem;
  line-height: 1.15;
}

.partner-login-card .minimal-booking-grid {
  grid-template-columns: 1fr;
  gap: 12px;
}

.partner-login-card .submit-cta {
  width: 100%;
  margin-top: 14px;
}

.partner-login-card .partner-login-join-box {
  padding: 0;
  border: 0;
  background: transparent;
}

.partner-login-card .partner-login-join-box a {
  width: 100%;
}

@media (min-width: 641px) and (max-width: 980px) {
  body.explore-baemin-page .explore-home-block {
    width: min(760px, calc(100% - 36px));
  }

  body.explore-baemin-page .explore-main-title {
    font-size: clamp(3.4rem, 8.4vw, 4.6rem);
  }
}

@media (max-width: 420px) {
  body.explore-baemin-page .explore-category-block .explore-icon-grid {
    gap: 8px;
  }

  body.explore-baemin-page .explore-category-block .explore-icon-grid button {
    min-height: 86px;
    border-radius: 18px;
  }
}

.triptalk-booking-box {
  margin-top: 32px;
  padding: 24px;
  border-radius: 18px;
  color: #fff;
  background: #164d56;
}

.triptalk-booking-box .eyebrow,
.triptalk-booking-box p {
  color: #b6d5d3;
}

.triptalk-booking-box h2 {
  margin-bottom: 8px;
  color: #fff;
}

.triptalk-booking-box .secondary-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: 12px;
  padding: 13px 16px;
  border-radius: 10px;
  color: #164d56;
  background: #fff;
}

.home-card,
.popular-grid a {
  display: grid;
  gap: 8px;
  padding: 20px;
  border: 1px solid #dce7e9;
  border-radius: 16px;
  color: #16313e;
  text-decoration: none;
  background: #fff;
}

.triptalk-pick-slider {
  display: flex;
  gap: 14px;
  overflow-x: auto;
  padding: 4px 2px 18px;
  cursor: grab;
}

.triptalk-pick-card {
  position: relative;
  overflow: hidden;
  flex: 0 0 min(310px, 78vw);
  display: grid;
  align-content: end;
  min-height: 250px;
  gap: 9px;
  padding: 18px;
  border-radius: 18px;
  color: #fff;
  text-decoration: none;
  background: #143f48;
  box-shadow: 0 14px 28px rgba(20, 72, 82, 0.14);
}

.triptalk-pick-card::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background:
    linear-gradient(180deg, rgba(0, 0, 0, 0.02), rgba(0, 0, 0, 0.78)),
    radial-gradient(circle at 22% 18%, rgba(255, 255, 255, 0.28), transparent 24%),
    linear-gradient(135deg, #12636b, #0f2f42);
}

.triptalk-pick-card.itinerary::before {
  background:
    linear-gradient(180deg, rgba(0, 0, 0, 0.02), rgba(0, 0, 0, 0.76)),
    radial-gradient(circle at 72% 20%, rgba(255, 226, 145, 0.76), transparent 22%),
    linear-gradient(135deg, #277a8c, #153f53 54%, #d88943);
}

.triptalk-pick-card.seafood::before {
  background:
    linear-gradient(180deg, rgba(0, 0, 0, 0.02), rgba(0, 0, 0, 0.78)),
    radial-gradient(circle at 26% 24%, rgba(135, 220, 255, 0.72), transparent 25%),
    linear-gradient(135deg, #0c5b73, #164d56 50%, #e06b2d);
}

.triptalk-pick-card.night::before {
  background:
    linear-gradient(180deg, rgba(0, 0, 0, 0.03), rgba(0, 0, 0, 0.82)),
    radial-gradient(circle at 78% 18%, rgba(255, 239, 165, 0.72), transparent 20%),
    linear-gradient(135deg, #071b31, #23326d 54%, #8e4a95);
}

.triptalk-pick-card.massage::before {
  background:
    linear-gradient(180deg, rgba(0, 0, 0, 0.02), rgba(0, 0, 0, 0.76)),
    radial-gradient(circle at 24% 20%, rgba(255, 204, 183, 0.72), transparent 24%),
    linear-gradient(135deg, #173f48, #6d3e71 52%, #c86b47);
}

.triptalk-pick-card > * {
  position: relative;
  z-index: 1;
}

.triptalk-pick-card span {
  color: rgba(255, 255, 255, 0.76);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.08em;
}

.triptalk-pick-card strong {
  font-size: 1.24rem;
  line-height: 1.22;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}

.triptalk-pick-card small {
  color: rgba(255, 255, 255, 0.86);
  line-height: 1.5;
}

.home-card span,
.popular-grid span {
  color: #3f8587;
  font-size: 0.78rem;
  font-weight: 800;
}

.home-card h2,
.home-card p {
  margin: 0;
}

.home-card p {
  color: #647780;
  line-height: 1.6;
}

.schedule-summary,
.schedule-list {
  display: grid;
  gap: 14px;
  margin: 20px 0;
}

.summary-pill,
.schedule-card {
  padding: 18px;
  border: 1px solid #dce7e9;
  border-radius: 16px;
  background: #fff;
}

.summary-pill strong {
  display: block;
  font-size: 2rem;
}

.schedule-card {
  display: grid;
  gap: 12px;
}

.schedule-card span {
  color: #3f8587;
  font-size: 0.78rem;
  font-weight: 800;
}

.schedule-card h2,
.schedule-card p {
  margin: 0;
}

.secondary-button-like {
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 12px 14px;
  border: 1px solid #cbd8dd;
  border-radius: 10px;
  color: #34505e;
  font-weight: 800;
  text-decoration: none;
  background: #fff;
}

.button-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.mini-card-grid {
  display: grid;
  gap: 10px;
  margin-top: 14px;
}

.mini-card {
  padding: 14px;
  border: 1px solid #dce7e9;
  border-radius: 14px;
  background: #fff;
}

.partner-checklist {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 10px;
  padding: 0;
  margin: 18px 0;
  list-style: none;
}

.partner-checklist li {
  border: 1px solid #dce7e9;
  border-radius: 999px;
  padding: 10px 14px;
  color: #617684;
  background: #fff;
  font-weight: 800;
}

.partner-checklist li.is-done {
  border-color: rgba(16, 118, 126, 0.3);
  color: #0f747b;
  background: #edf8f6;
}

.checkbox-label {
  display: flex;
  gap: 10px;
  align-items: center;
  font-weight: 900;
}

.checkbox-label input {
  width: auto;
  min-height: auto;
}

.partner-tabs {
  position: sticky;
  top: 0;
  z-index: 40;
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding: 10px 0 14px;
  scrollbar-width: thin;
  background: rgba(246, 252, 251, 0.94);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

.partner-tabs button {
  cursor: pointer;
  flex: 0 0 auto;
  padding: 11px 13px;
  border: 1px solid #cbd8dd;
  border-radius: 999px;
  color: #34505e;
  font-weight: 800;
  background: #fff;
}

.partner-tabs button.active {
  border-color: #11636c;
  color: #fff;
  background: #11636c;
}

.partner-link-copy-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 16px;
  align-items: center;
  margin: 18px 0;
  padding: 18px;
  border: 1px solid rgba(17, 99, 108, 0.24);
  border-radius: 20px;
  background: linear-gradient(135deg, rgba(232, 251, 247, 0.95), rgba(255, 255, 255, 0.96));
  box-shadow: 0 16px 38px rgba(10, 72, 78, 0.08);
}

.partner-link-copy-card span {
  display: block;
  margin-bottom: 6px;
  color: #0d7478;
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.partner-link-copy-card strong {
  display: block;
  overflow-wrap: anywhere;
  color: #092f3a;
  font-size: clamp(1rem, 2vw, 1.2rem);
}

.partner-link-copy-card p {
  margin: 8px 0 0;
  color: #59717b;
  font-size: 0.92rem;
}

.partner-panel {
  display: grid;
  gap: 18px;
}

.partner-panel[hidden] {
  display: none;
}

.partner-dashboard-main {
  max-width: 1180px;
}

.partner-priority-metrics .mini-card strong {
  font-size: clamp(1.8rem, 3vw, 2.8rem);
}

.partner-priority-metrics .mini-card:first-child {
  border-color: rgba(14, 165, 233, 0.38);
  background: linear-gradient(135deg, rgba(14, 165, 233, 0.14), rgba(255, 255, 255, 0.94));
}

@media (min-width: 900px) {
  .partner-dashboard-main .compact-booking-card,
  .partner-dashboard-main .chat-language-note,
  .partner-dashboard-main .partner-panel {
    max-width: none;
  }

  .partner-dashboard-main .partner-tabs {
    justify-content: flex-start;
  }

  .partner-desktop-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  .partner-tabs {
    margin: 0 -12px 8px;
    padding-inline: 12px;
  }

  .partner-link-copy-card {
    grid-template-columns: 1fr;
  }

  .partner-link-copy-card .primary-cta {
    width: 100%;
  }
}

.review-slider {
  display: flex;
  gap: 14px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  margin-right: -22px;
  padding: 6px 22px 18px 0;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
}

.review-slider::-webkit-scrollbar {
  display: none;
}

.review-slide-card {
  position: relative;
  overflow: hidden;
  flex: 0 0 235px;
  display: grid;
  align-content: end;
  min-height: 190px;
  gap: 8px;
  scroll-snap-align: start;
  padding: 18px;
  border-radius: 18px;
  color: #fff;
  text-decoration: none;
  background:
    linear-gradient(180deg, rgba(0, 0, 0, 0.02), rgba(0, 0, 0, 0.78)),
    radial-gradient(circle at 72% 16%, rgba(255, 214, 145, 0.75), transparent 26%),
    linear-gradient(135deg, #164d56, #102c42 58%, #e06b2d);
  box-shadow: 0 14px 28px rgba(20, 72, 82, 0.14);
}

.review-slide-card span,
.review-slide-card p,
.review-slide-card strong {
  position: relative;
  z-index: 1;
  margin: 0;
}

.review-slide-card span {
  width: fit-content;
  padding: 5px 8px;
  border-radius: 999px;
  color: rgba(255, 255, 255, 0.9);
  font-size: 0.66rem;
  font-weight: 800;
  background: rgba(0, 0, 0, 0.28);
}

.review-slide-card strong {
  font-size: 2rem;
}

.review-slide-card p {
  color: rgba(255, 255, 255, 0.82);
  font-weight: 800;
}

.google-review-card {
  align-content: start;
}

.google-review-card strong {
  font-size: 1rem;
  line-height: 1.35;
}

.google-review-card p {
  font-size: 0.9rem;
  line-height: 1.55;
}

.google-review-card small {
  position: relative;
  z-index: 1;
  color: rgba(255, 255, 255, 0.72);
  font-weight: 800;
}

.place-review-section .accordion-body {
  display: grid;
  gap: 14px;
}

.review-toggle-button {
  width: 100%;
}

.place-review-form {
  display: grid;
  gap: 12px;
  padding: 14px;
  border: 1px solid rgba(15, 23, 42, 0.12);
  border-radius: 8px;
  background: #fff;
}

.place-review-form[hidden] {
  display: none;
}

.place-review-form label {
  display: grid;
  gap: 6px;
  font-size: 0.86rem;
  font-weight: 800;
  color: #334155;
}

.place-review-form input,
.place-review-form select,
.place-review-form textarea {
  width: 100%;
  min-width: 0;
  border: 1px solid rgba(15, 23, 42, 0.14);
  border-radius: 8px;
  padding: 11px 12px;
  font: inherit;
  background: #fff;
  color: #0f172a;
}

.review-form-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 10px;
}

.review-form-grid.compact {
  grid-template-columns: minmax(0, 1.25fr) minmax(0, 0.75fr);
}

.review-photo-picker {
  justify-items: start;
  width: max-content;
  max-width: 100%;
  padding: 10px 14px;
  border-radius: 8px;
  background: #0f172a;
  color: #fff !important;
}

.customer-review-list {
  display: grid;
  gap: 12px;
}

.google-review-visible-block {
  margin-top: 12px;
}

.google-review-visible-block.mobile-accordion {
  display: block;
  padding: 0;
}

.customer-review-card {
  display: grid;
  gap: 10px;
  padding: 14px;
  border: 1px solid rgba(15, 23, 42, 0.1);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06);
}

.customer-review-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.customer-review-head strong,
.customer-review-head span {
  min-width: 0;
  overflow-wrap: anywhere;
}

.customer-review-head span {
  color: #f59e0b;
  white-space: nowrap;
}

.customer-review-card p {
  margin: 0;
  color: #334155;
  line-height: 1.62;
  overflow-wrap: anywhere;
}

.customer-review-photos {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(108px, 42%);
  gap: 8px;
  overflow-x: auto;
  padding-bottom: 2px;
}

.customer-review-photos img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  border-radius: 8px;
  border: 1px solid rgba(15, 23, 42, 0.08);
}

.share-place-button {
  border: 0;
  cursor: pointer;
}

@media (max-width: 520px) {
  .review-form-grid,
  .review-form-grid.compact {
    grid-template-columns: 1fr;
  }
}

@media (min-width: 760px) {
  .site-header {
    padding: 20px 32px;
  }

  main {
    padding-right: 28px;
    padding-left: 28px;
  }

  .hero {
    grid-template-columns: minmax(0, 1fr) 270px;
    padding: 88px 0 58px;
  }

  .link-section {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .inquiry-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .quick-plan-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .recommended-course-card {
    flex-basis: 285px;
  }

  .place-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .explore-detail-grid,
  .shorts-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .menu-grid {
    grid-template-columns: 1fr;
  }

  .triptalk-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .home-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .schedule-summary {
    grid-template-columns: repeat(2, 180px);
  }

  .schedule-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .dashboard-columns {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
  }

  .mini-card-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .popular-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .vehicle-price-cards {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .after-tour-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .tour-priority-grid {
    grid-template-columns: 1.2fr repeat(3, minmax(0, 1fr));
  }

  .inquiry-grid .wide {
    grid-column: 1 / -1;
  }

  .mobile-cta {
    display: none;
  }
}

@media (max-width: 980px) {
  .metric-xl-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .partner-inquiry-hero {
    grid-template-columns: 1fr;
    padding-top: 40px;
  }

  .partner-mobile-shell {
    grid-template-columns: 1fr;
  }

  .partner-value-grid,
  .partner-flow-grid,
  .partner-simple-plan-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .home-main-entry-grid {
    grid-template-columns: 1fr;
  }

  .explore-business-grid {
    grid-template-columns: 1fr;
  }

  .home-payment-strip {
    width: 100%;
  }

  .airport-vehicle-choice-grid {
    grid-template-columns: 1fr;
  }

  .tour-addon-panel {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .section-title-row {
    display: grid;
  }

  .slider-controls {
    display: none;
  }

  .course-slider-shell {
    margin-right: -18px;
    margin-left: -18px;
    padding-left: 18px;
  }

  .recommended-course-slider {
    gap: 12px;
    padding: 4px 18px 18px 0;
    scroll-padding-left: 18px;
  }

  .recommended-course-card {
    flex-basis: min(76vw, 300px);
    min-height: 300px;
  }

  .location-search-row,
  .place-add-row {
    grid-template-columns: 1fr;
  }

  .sns-next-actions,
  .phone-capture-row {
    grid-template-columns: 1fr;
  }

  .home-payment-strip {
    align-items: flex-start;
    flex-direction: column;
  }

  .place-route-item {
    grid-template-columns: 1fr;
  }

  .arrival-confirm-box {
    grid-template-columns: 1fr;
  }

  .route-order-actions {
    justify-content: flex-end;
  }

  .tour-priority-grid.home-drag-slider,
  .popular-grid.home-drag-slider,
  .home-grid.home-drag-slider,
  .triptalk-pick-slider.home-drag-slider {
    display: flex;
    gap: 12px;
    overflow-x: auto;
    margin-right: -18px;
    margin-left: -18px;
    padding: 4px 18px 18px;
    cursor: grab;
  }

  .tour-priority-grid.home-drag-slider > * {
    flex: 0 0 min(76vw, 300px);
    min-height: 300px;
  }

  .popular-grid.home-drag-slider > * {
    flex: 0 0 min(70vw, 260px);
    min-height: 132px;
  }

  .home-grid.home-drag-slider > * {
    flex: 0 0 min(74vw, 290px);
    min-height: 210px;
  }

  .triptalk-pick-slider.home-drag-slider > * {
    flex: 0 0 min(76vw, 300px);
    min-height: 280px;
  }

  .metric-xl-grid {
    grid-template-columns: 1fr;
  }

  .partner-value-grid,
  .partner-flow-grid {
    grid-template-columns: 1fr;
  }

  .partner-inquiry-hero h1 {
    font-size: clamp(2.1rem, 12vw, 3.6rem);
  }

  .partner-apply-hero {
    padding: 30px 18px 20px;
  }

  .partner-apply-hero h1 {
    font-size: clamp(2.2rem, 12vw, 3.8rem);
  }

  .partner-mobile-shell {
    width: calc(100% - 28px);
    margin-top: 18px;
  }

  .partner-apply-form,
  .partner-result-actions,
  .partner-simple-plan-grid {
    grid-template-columns: 1fr;
  }

  .partner-apply-section-grid {
    grid-template-columns: 1fr;
    padding: 14px;
  }

  .partner-upload-zone,
  .partner-menu-builder,
  .partner-link-list,
  .partner-link-list-block {
    padding: 14px;
  }

  .partner-menu-row {
    grid-template-columns: 1fr 0.72fr;
    gap: 8px;
    border: 1px solid #d6e6e8;
    border-radius: 14px;
    padding: 10px;
    background: #fff;
  }

  .partner-menu-row .menu-name,
  .partner-menu-row .menu-description {
    grid-column: 1 / -1;
  }

  .partner-menu-row .partner-row-remove {
    grid-column: 1 / -1;
  }

  .partner-link-row {
    grid-template-columns: 1fr;
  }

  .partner-check-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .partner-small-button {
    width: calc(100% - 28px);
    margin: 0 14px 14px;
  }

  .partner-upload-preview-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .partner-apply-card,
  .partner-plan-mobile-card,
  .partner-result-card {
    border-radius: 20px;
  }

  .partner-apply-form input,
  .partner-apply-form select,
  .partner-apply-form textarea {
    font-size: 16px;
  }

  .reservation-confirmation-page {
    gap: 12px;
    width: calc(100% + 4px);
    max-width: none;
    margin: 20px -2px;
    padding-bottom: 16px;
    border-radius: 18px;
  }

  .explore-result-list {
    width: calc(100% - 28px);
    gap: 12px;
    margin-top: 16px;
  }

  .explore-list-heading {
    align-items: start;
  }

  .compact-explore-card .explore-list-photo {
    min-height: 178px;
  }

  .explore-list-overlay {
    right: 12px;
    bottom: 12px;
    left: 12px;
  }

  .explore-list-overlay .explore-list-title-row h2 {
    font-size: 1.28rem;
  }

  .explore-list-mini-meta {
    padding: 8px 10px 10px;
  }

  .reservation-confirmation-hero {
    padding: 24px 14px;
    border-radius: 18px 18px 0 0;
  }

  .reservation-confirmation-hero h2 {
    font-size: clamp(1.5rem, 8vw, 2rem);
  }

  .reservation-summary-card,
  .reservation-code-card,
  .inline-reservation-chat,
  .post-complete-picks {
    margin: 0 10px;
    padding: 14px;
    border-radius: 16px;
  }

  .reservation-summary-card > strong {
    font-size: 1.35rem;
  }

  .reservation-summary-card dl {
    gap: 6px;
  }

  .reservation-summary-card dl div {
    display: grid;
    grid-template-columns: 90px minmax(0, 1fr);
    gap: 8px;
  }

  .reservation-summary-card dt,
  .reservation-summary-card dd {
    font-size: 0.92rem;
  }

  .reservation-summary-card dd {
    overflow-wrap: anywhere;
    text-align: right;
  }

  .inline-chat-header {
    padding: 13px 14px;
  }

  .inline-chat-messages {
    min-height: 260px;
    max-height: 430px;
    padding: 12px;
  }

  .inline-chat-bubble {
    max-width: 86%;
    padding: 10px 12px;
    border-radius: 15px;
  }

  .inline-chat-tools {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    padding: 12px;
  }

  .inline-chat-tools button:first-child {
    grid-column: 1 / -1;
  }

  .inline-chat-input-row {
    display: grid;
    grid-template-columns: 56px minmax(0, 1fr) 64px;
    gap: 8px;
    padding: 0 12px 12px;
  }

  .inline-chat-input-row input {
    min-width: 0;
    font-size: 16px;
  }

  .inline-photo-button,
  .inline-chat-input-row button {
    min-height: 46px;
    padding: 0 10px;
    justify-content: center;
    text-align: center;
  }

  .inline-chat-note {
    padding: 0 12px 14px;
    font-size: 0.86rem;
  }

  .contact-choice-card {
    padding: 13px;
    border-radius: 15px;
  }

  .partner-cta-band {
    margin-inline: 18px;
    padding: 24px;
  }

  .site-footer {
    margin-top: 48px;
    padding: 26px 18px;
  }

  .site-footer-inner {
    display: grid;
    gap: 18px;
    align-items: start;
  }

  .site-footer nav {
    justify-content: stretch;
  }

  .site-footer a {
    flex: 1 1 140px;
  }
}

/* TripBusan review-ready polish
   Inspired by Visit Korea, Airbnb, Klook, SoiTaxi, and owner dashboards.
   This layer keeps existing functions intact while making pages feel like one product. */
body:not(.landing-only-page) {
  background:
    radial-gradient(circle at 88% 8%, rgba(36, 163, 158, 0.08), transparent 28%),
    linear-gradient(180deg, #fbfdfd 0%, #f6faf9 42%, #fbfcfc 100%);
}

body:not(.landing-only-page) .site-header {
  position: sticky;
  top: 0;
  z-index: 20;
  gap: 18px;
  border-bottom: 1px solid rgba(17, 99, 108, 0.13);
  background: rgba(255, 255, 255, 0.92);
  box-shadow: 0 12px 34px rgba(8, 55, 65, 0.06);
  backdrop-filter: blur(18px);
}

body:not(.landing-only-page) .logo {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  color: #0a515b;
  font-size: 1.28rem;
  font-weight: 950;
  letter-spacing: -0.065em;
}

body:not(.landing-only-page) .logo::before {
  content: "TB";
  display: inline-grid;
  width: 30px;
  height: 30px;
  place-items: center;
  border-radius: 8px;
  color: #fff;
  background: #092f3b;
  font-size: 0.7rem;
  letter-spacing: 0;
}

body:not(.landing-only-page) .site-header nav {
  display: flex;
  align-items: center;
  gap: 6px;
  overflow-x: auto;
  padding-bottom: 2px;
  scrollbar-width: none;
}

body:not(.landing-only-page) .site-header nav::-webkit-scrollbar {
  display: none;
}

body:not(.landing-only-page) .site-header nav a {
  flex: 0 0 auto;
  padding: 9px 11px;
  border-radius: 999px;
  color: #365a64;
  font-size: 0.9rem;
  font-weight: 850;
  text-decoration: none;
}

body:not(.landing-only-page) .site-header nav a:hover,
body:not(.landing-only-page) .site-header nav a:focus-visible {
  color: #fff;
  background: #0b7078;
}

body:not(.landing-only-page) main {
  width: min(1120px, calc(100% - 36px));
  max-width: 1120px;
  padding-right: 0;
  padding-left: 0;
}

body:not(.landing-only-page) .home-hero,
body:not(.landing-only-page) .explore-hero,
body:not(.landing-only-page) .inquiry-intro,
body:not(.landing-only-page) .partner-apply-hero {
  margin: 22px 0;
  padding: clamp(38px, 7vw, 78px) clamp(20px, 4vw, 44px);
  border: 1px solid rgba(17, 99, 108, 0.15);
  border-radius: 34px;
  background:
    radial-gradient(circle at 82% 18%, rgba(32, 163, 158, 0.18), transparent 28%),
    linear-gradient(135deg, #ffffff, #eef8f7);
  box-shadow: 0 24px 64px rgba(8, 55, 65, 0.1);
}

body:not(.landing-only-page) .home-hero h1,
body:not(.landing-only-page) .explore-hero h1,
body:not(.landing-only-page) .inquiry-intro h1,
body:not(.landing-only-page) .partner-apply-hero h1 {
  max-width: 860px;
  font-size: clamp(2.45rem, 7vw, 5.6rem);
  line-height: 0.96;
  letter-spacing: -0.078em;
}

body:not(.landing-only-page) .home-hero p:not(.eyebrow),
body:not(.landing-only-page) .explore-hero p:last-child,
body:not(.landing-only-page) .inquiry-intro p:not(.eyebrow) {
  max-width: 760px;
  color: #506b76;
  font-size: 1.05rem;
  line-height: 1.75;
}

body:not(.landing-only-page) .content-section,
body:not(.landing-only-page) .inquiry-card,
body:not(.landing-only-page) .quick-plan-card,
body:not(.landing-only-page) .partner-sales-card {
  margin: 22px 0;
  padding: clamp(24px, 4vw, 42px);
  border: 1px solid rgba(17, 99, 108, 0.14);
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.94);
  box-shadow: 0 18px 48px rgba(8, 55, 65, 0.08);
}

body:not(.landing-only-page) .content-section {
  border-top: 1px solid rgba(17, 99, 108, 0.14);
}

body:not(.landing-only-page) .eyebrow {
  color: #0b7a7e;
  font-weight: 950;
}

body:not(.landing-only-page) h2 {
  color: #132f3a;
  font-size: clamp(1.85rem, 4vw, 3.15rem);
  line-height: 1.05;
  letter-spacing: -0.06em;
}

body:not(.landing-only-page) .primary-cta,
body:not(.landing-only-page) button.primary-cta,
body:not(.landing-only-page) .submit-cta {
  min-height: 48px;
  border-radius: 999px;
  padding: 14px 20px;
  border: 0;
  background: #0b7078;
  box-shadow: 0 14px 30px rgba(10, 91, 99, 0.18);
  font-weight: 950;
}

body:not(.landing-only-page) .secondary-link,
body:not(.landing-only-page) .secondary-button-like,
body:not(.landing-only-page) .text-button {
  border-radius: 999px;
  font-weight: 900;
}

body:not(.landing-only-page) input,
body:not(.landing-only-page) select,
body:not(.landing-only-page) textarea {
  border-color: rgba(17, 99, 108, 0.22);
  border-radius: 14px;
  background: #fff;
}

body:not(.landing-only-page) input:focus,
body:not(.landing-only-page) select:focus,
body:not(.landing-only-page) textarea:focus {
  outline: 3px solid rgba(32, 163, 158, 0.16);
  border-color: #0b7078;
}

@media (max-width: 760px) {
  body:not(.landing-only-page) .site-header {
    display: grid;
    padding: 14px 16px;
  }

  body:not(.landing-only-page) main {
    width: calc(100% - 28px);
  }

  body:not(.landing-only-page) .home-hero,
  body:not(.landing-only-page) .explore-hero,
  body:not(.landing-only-page) .inquiry-intro,
  body:not(.landing-only-page) .partner-apply-hero {
    border-radius: 24px;
    padding: 30px 18px;
  }

  body:not(.landing-only-page) .content-section,
  body:not(.landing-only-page) .inquiry-card,
  body:not(.landing-only-page) .quick-plan-card,
  body:not(.landing-only-page) .partner-sales-card {
    border-radius: 22px;
    padding: 20px 16px;
  }
}

@media (max-width: 640px) {
  .inquiry-intro,
  .inquiry-card,
  .first-day-panel,
  .reservation-request-section,
  .reservation-code-card,
  .inline-chat-panel,
  .inline-reservation-chat {
    padding: 16px;
    border-radius: 18px;
  }

  .inquiry-intro h1,
  .first-day-panel h2,
  .reservation-request-section h2,
  .section-title-row h2 {
    font-size: clamp(1.65rem, 8vw, 2.35rem);
    line-height: 1.05;
  }

  .inquiry-intro p,
  .minimal-form-note,
  .form-hint,
  .memory-note,
  .slider-help,
  .reservation-code-card p,
  .inline-chat-note,
  .reservation-request-section > p:not(.eyebrow) {
    font-size: 0.92rem;
    line-height: 1.48;
  }

  .inquiry-grid {
    gap: 10px;
    grid-template-columns: 1fr !important;
  }

  .minimal-inquiry-grid,
  .nested-grid,
  .reservation-request-section .inquiry-grid,
  .booking-type-grid,
  .vehicle-price-cards,
  .location-search-row,
  .place-add-row,
  .arrival-confirm-box {
    grid-template-columns: 1fr !important;
  }

  .inquiry-grid .wide,
  .reservation-request-section .wide {
    grid-column: 1 / -1;
  }

  .inquiry-grid input,
  .inquiry-grid select,
  .inquiry-grid textarea,
  body:not(.landing-only-page) input,
  body:not(.landing-only-page) select,
  body:not(.landing-only-page) textarea {
    min-height: 48px;
    padding: 11px 13px;
    font-size: 16px;
  }

  .inquiry-grid textarea,
  body:not(.landing-only-page) textarea {
    min-height: 74px;
  }

  .explore-detail-hero {
    grid-template-columns: 1fr;
    gap: 16px;
    padding-top: 28px;
  }

  .explore-hero-photo-button {
    border-radius: 18px;
  }

  .reservation-menu-row {
    grid-template-columns: 58px minmax(0, 1fr) auto;
    gap: 9px;
    padding: 8px;
  }

  .reservation-menu-row img,
  .reservation-menu-row .compact-menu-photo-placeholder {
    width: 58px;
    height: 58px;
    border-radius: 10px;
  }

  .reservation-menu-info strong {
    font-size: 0.94rem;
  }

  .reservation-menu-info span {
    font-size: 0.84rem;
  }

  .customer-image-preview-nav {
    width: 42px;
    height: 42px;
    font-size: 1.7rem;
  }

  .customer-image-preview-prev {
    left: 4px;
  }

  .customer-image-preview-next {
    right: 4px;
  }

  .sns-next-actions {
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .sns-verification-card {
    gap: 7px;
    margin: 10px 0;
    padding: 12px;
    border-radius: 16px;
  }

  .sns-verification-card p {
    font-size: 0.9rem;
    line-height: 1.45;
  }

  .booking-chat-thread,
  .inline-chat-messages {
    max-height: 360px;
    padding: 10px;
  }

  .booking-chat-bubble {
    max-width: 94%;
    padding: 11px 12px;
    border-radius: 15px;
  }

  .booking-chat-bubble p,
  .booking-chat-bubble small,
  .inline-chat-bubble p,
  .inline-chat-bubble em,
  .voucher-detail-list dd,
  .reservation-summary-card dd,
  .reservation-summary-card > strong,
  .memory-note {
    overflow-wrap: anywhere;
    word-break: break-word;
  }

  .inline-chat-input-row {
    grid-template-columns: 48px minmax(0, 1fr) 58px !important;
  }

  .inline-photo-button,
  .inline-chat-input-row button {
    padding-inline: 8px;
    font-size: 0.86rem;
  }
}
/* Flat reservation UI pass: SoiTaxi-like, mobile-first, fewer nested cards. */
.booking-benefit-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin-top: 16px;
}

.booking-benefit-strip span {
  display: grid;
  place-items: center;
  min-height: 44px;
  padding: 8px 10px;
  border: 1px solid rgba(11, 112, 120, 0.16);
  border-radius: 999px;
  color: #0b5961;
  background: #f3fbfa;
  font-size: 0.82rem;
  font-weight: 950;
  text-align: center;
}

.pay-later-mini-note {
  display: grid;
  gap: 4px;
  margin: 14px 0 8px;
  padding: 12px 14px;
  border-radius: 16px;
  background: #eef8f7;
  color: #12323d;
}

.pay-later-mini-note strong {
  color: #0b5961;
  font-size: 0.98rem;
}

.pay-later-mini-note span,
.cancel-mini-note {
  color: #536e78;
  font-size: 0.92rem;
  line-height: 1.45;
}

.cancel-mini-note {
  margin: 0 0 12px;
}

.join-tour-detail {
  display: grid;
  gap: 16px;
  margin: 0 0 18px;
  padding: 0 0 18px;
  border-bottom: 1px solid #dce8e8;
}

.join-tour-summary {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 16px;
}

.join-tour-summary h2 {
  max-width: 640px;
  margin: 4px 0 8px;
  color: #102f3a;
  font-size: clamp(1.65rem, 4.5vw, 2.65rem);
  line-height: 1.05;
  letter-spacing: -0.045em;
}

.join-tour-summary p:not(.eyebrow) {
  max-width: 640px;
  margin: 0;
  color: #536e78;
  line-height: 1.6;
}

.join-course-list {
  display: grid;
  gap: 9px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.join-course-list li {
  display: grid;
  grid-template-columns: 34px 1fr;
  grid-template-areas:
    "num title"
    "num desc";
  gap: 2px 10px;
  align-items: center;
  padding: 12px 0;
  border-top: 1px solid rgba(20, 78, 88, 0.12);
}

.join-course-list li:first-child {
  border-top: 0;
}

.join-course-list span {
  grid-area: num;
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border-radius: 999px;
  background: #0f7b82;
  color: #fff;
  font-weight: 900;
  font-size: 0.9rem;
}

.join-course-list strong {
  grid-area: title;
  color: #102f3a;
  font-size: 1.02rem;
}

.join-course-list small {
  grid-area: desc;
  color: #5d7480;
  line-height: 1.45;
}

.join-tour-notes {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.join-tour-notes span {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 7px 11px;
  border-radius: 999px;
  background: #eef8f6;
  color: #25535b;
  font-weight: 800;
  font-size: 0.84rem;
}

body:not(.landing-only-page) .inquiry-main {
  max-width: 900px;
  padding-top: 22px;
}

body:not(.landing-only-page) .inquiry-intro {
  margin-bottom: 14px;
  padding: 0 0 16px;
  border: 0;
  border-bottom: 1px solid #dce8e8;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

body:not(.landing-only-page) .inquiry-intro h1 {
  max-width: 760px;
  margin: 4px 0 8px;
  font-size: clamp(2.35rem, 7vw, 4.6rem);
  line-height: 0.98;
  letter-spacing: -0.07em;
}

body:not(.landing-only-page) .inquiry-intro p:not(.eyebrow) {
  max-width: 680px;
  margin: 0;
  color: #536e78;
  font-size: 1.03rem;
  line-height: 1.55;
}

body:not(.landing-only-page) .inquiry-card,
body:not(.landing-only-page) .quick-plan-card,
body:not(.landing-only-page) .course-builder-card,
body:not(.landing-only-page) .favorite-route-section,
body:not(.landing-only-page) .first-day-panel,
body:not(.landing-only-page) .vehicle-price-panel,
body:not(.landing-only-page) .tour-addon-panel,
body:not(.landing-only-page) .place-editor,
body:not(.landing-only-page) .dropoff-quick,
body:not(.landing-only-page) .after-tour-panel,
body:not(.landing-only-page) .inquiry-complete,
body:not(.landing-only-page) .inline-chat-panel,
body:not(.landing-only-page) .reservation-request-section {
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

body:not(.landing-only-page) .inquiry-card,
body:not(.landing-only-page) .quick-plan-card,
body:not(.landing-only-page) .course-builder-card,
body:not(.landing-only-page) .favorite-route-section,
body:not(.landing-only-page) .inquiry-complete {
  padding: 14px 0;
}

body:not(.landing-only-page) .first-day-panel,
body:not(.landing-only-page) .vehicle-price-panel,
body:not(.landing-only-page) .tour-addon-panel,
body:not(.landing-only-page) .place-editor,
body:not(.landing-only-page) .dropoff-quick,
body:not(.landing-only-page) .after-tour-panel,
body:not(.landing-only-page) .reservation-request-section {
  margin: 0;
  padding: 14px 0;
  border-top: 1px solid #edf3f3;
}

body:not(.landing-only-page) .first-day-panel h2,
body:not(.landing-only-page) .vehicle-price-panel h2,
body:not(.landing-only-page) .tour-addon-panel h2,
body:not(.landing-only-page) .place-editor h2,
body:not(.landing-only-page) .section-title-row h2 {
  margin: 3px 0 6px;
  font-size: clamp(1.5rem, 3.2vw, 2.25rem);
  line-height: 1.08;
  letter-spacing: -0.045em;
}

body:not(.landing-only-page) .selected-tour,
body:not(.landing-only-page) .compact-hidden-selected-tour {
  display: none !important;
}

body:not(.landing-only-page) .inquiry-grid,
body:not(.landing-only-page) .minimal-inquiry-grid,
body:not(.landing-only-page) .minimal-booking-grid {
  gap: 12px;
}

body:not(.landing-only-page) label {
  gap: 6px;
  color: #17323d;
  font-size: 0.9rem;
  font-weight: 900;
}

body:not(.landing-only-page) input,
body:not(.landing-only-page) select,
body:not(.landing-only-page) textarea {
  min-height: 52px;
  border-radius: 12px;
  font-size: 16px;
}

body:not(.landing-only-page) textarea {
  min-height: 78px;
}

body:not(.landing-only-page) .primary-cta,
body:not(.landing-only-page) .submit-cta,
body:not(.landing-only-page) .secondary-button-like,
body:not(.landing-only-page) .sns-next-actions a,
body:not(.landing-only-page) .sns-next-actions button {
  min-height: 52px;
  border-radius: 13px;
  font-weight: 950;
}

body:not(.landing-only-page) .submit-cta {
  width: 100%;
  margin-top: 10px;
  font-size: 1.02rem;
}

body:not(.landing-only-page) .memory-note,
body:not(.landing-only-page) .form-hint,
body:not(.landing-only-page) .minimal-form-note,
body:not(.landing-only-page) .slider-help {
  padding: 0;
  border: 0;
  background: transparent;
  color: #647982;
  font-size: 0.88rem;
}

body:not(.landing-only-page) details {
  border: 1px solid #ddeaea;
  border-radius: 14px;
  background: #ffffff;
}

body:not(.landing-only-page) details > summary {
  min-height: 48px;
  padding: 13px 14px;
  font-weight: 950;
}

body:not(.landing-only-page) .flight-list-box {
  display: grid;
  gap: 8px;
}

body:not(.landing-only-page) .arrival-confirm-box,
body:not(.landing-only-page) .usage-summary,
body:not(.landing-only-page) .price-estimate {
  padding: 12px 14px;
  border-radius: 14px;
  background: #eef8f7;
}

body:not(.landing-only-page) .sns-verification-card {
  margin: 12px 0;
  padding: 14px;
  border: 1px solid #ffd7d0;
  border-radius: 16px;
  background: #fff6f3;
}

body:not(.landing-only-page) .sns-verification-card strong {
  display: block;
  color: #e95d4f;
  font-size: clamp(2.1rem, 9vw, 3.2rem);
  letter-spacing: 0.08em;
}

body:not(.landing-only-page) .sns-next-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

body:not(.landing-only-page) .chat-message-list,
body:not(.landing-only-page) .inline-chat-messages {
  max-height: 300px;
  padding: 10px;
  border-radius: 16px;
  background: #f4f8f8;
}

body:not(.landing-only-page) .booking-chat-bubble,
body:not(.landing-only-page) .chat-message-card,
body:not(.landing-only-page) .inline-chat-bubble {
  border-radius: 15px;
  box-shadow: none;
}

@media (max-width: 760px) {
  body:not(.landing-only-page) main,
  body:not(.landing-only-page) .inquiry-main {
    width: calc(100% - 24px);
    padding-top: 16px;
  }

  body:not(.landing-only-page) .inquiry-intro {
    padding: 0 0 14px;
  }

  body:not(.landing-only-page) .inquiry-intro h1 {
    font-size: clamp(2.18rem, 12vw, 3.35rem);
  }

  .booking-benefit-strip {
    grid-template-columns: 1fr;
    gap: 7px;
  }

  .booking-benefit-strip span {
    min-height: 40px;
  }

  .join-tour-summary {
    display: grid;
    gap: 12px;
  }

  .join-tour-summary .secondary-button-like {
    width: 100%;
    justify-content: center;
  }

  .join-course-list li {
    padding: 10px 0;
  }

  .filter-label {
    width: calc(100% - 24px);
    margin-top: 14px;
  }

  .explore-result-list {
    width: calc(100% - 24px);
    gap: 12px;
  }

  .explore-list-heading {
    align-items: start;
  }

  .explore-list-heading > strong {
    font-size: 0.76rem;
    padding: 7px 9px;
  }

  .explore-list-card-link {
    grid-template-columns: 1fr;
    gap: 10px;
    padding: 10px;
  }

  .explore-list-photo {
    min-height: 190px;
  }

  .explore-list-body {
    padding: 4px 4px 60px;
  }

  .explore-list-actions {
    right: 10px;
    bottom: 10px;
    left: 10px;
  }

  .explore-save-button,
  .explore-reserve-button {
    flex: 1;
    justify-content: center;
    text-align: center;
  }

  body:not(.landing-only-page) .sns-next-actions {
    grid-template-columns: 1fr;
  }

  body:not(.landing-only-page) .course-builder-card {
    padding-top: 6px;
  }
}

@media (max-width: 760px) {
  .voucher-soitaxi {
    width: 100%;
    padding: 8px 10px 24px;
  }

  .voucher-soitaxi .voucher-top-card,
  .voucher-soitaxi .voucher-info-card,
  .voucher-soitaxi .voucher-driver-card {
    border-radius: 18px;
    margin-bottom: 12px;
    padding: 14px;
  }

  .voucher-key-list div,
  .voucher-driver-list div {
    grid-template-columns: 92px minmax(0, 1fr);
  }

  .voucher-key-list dt,
  .voucher-key-list dd,
  .voucher-driver-list span,
  .voucher-driver-list strong {
    font-size: 0.92rem;
  }

  .voucher-info-actions,
  .voucher-soitaxi .voucher-visible-actions,
  .voucher-soitaxi .voucher-quick-phrases {
    grid-template-columns: 1fr;
  }

  .voucher-chat-list {
    max-height: 470px;
    min-height: 260px;
    padding: 10px;
  }

  .voucher-chat-list .chat-message-card {
    max-width: 86%;
  }

.voucher-soitaxi #voucher-sender-type {
    display: none;
  }
}

.compact-explore-reservation-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.exploration-info-list {
  display: grid;
  gap: 12px;
  margin: 16px 0;
}

.exploration-info-list div {
  display: grid;
  grid-template-columns: 72px 1fr;
  gap: 12px;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(15, 80, 86, 0.1);
}

.exploration-info-list dt {
  color: #5b7378;
  font-weight: 800;
}

.exploration-info-list dd {
  margin: 0;
  color: #15323a;
}

.compact-explore-reservation-grid input[type="hidden"] {
  display: none;
}

@media (max-width: 760px) {
  .compact-explore-reservation-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 700px) {
  .landing-menu-card-grid.home-service-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 10px !important;
  }

  .landing-menu-card-grid.home-service-grid .landing-menu-card {
    min-height: 148px !important;
    padding: 14px 12px !important;
    border-radius: 22px;
  }

  .landing-menu-card-grid.home-service-grid .landing-menu-card::after {
    top: 12px;
    right: 12px;
    width: 34px;
    height: 34px;
    font-size: 0.95rem;
  }

  .landing-menu-card-grid.home-service-grid .landing-menu-card span {
    font-size: 1.5rem !important;
  }

  .landing-menu-card-grid.home-service-grid .landing-menu-card strong {
    max-width: 92%;
    font-size: 1rem !important;
    line-height: 1.08 !important;
  }

  .landing-menu-card-grid.home-service-grid .landing-menu-card small {
    display: none !important;
  }

  .traveler-explore-section {
    padding: 24px 16px !important;
  }

  .traveler-explore-section .landing-section-heading h2 {
    font-size: clamp(1.75rem, 8vw, 2.35rem) !important;
  }

  .traveler-explore-section .landing-section-heading p:not(.eyebrow) {
    font-size: 0.95rem !important;
    line-height: 1.5 !important;
  }

  .home-explore-image-cta {
    min-height: 170px;
    padding: 18px;
    border-radius: 22px;
  }

  .home-explore-image-cta strong {
    font-size: clamp(1.55rem, 7vw, 2.15rem);
  }

  .home-explore-image-cta small {
    font-size: 0.9rem;
  }
}

/* Bright mobile landing palette: mint, white, cream, and sunny accents. */
body.landing-only-page {
  --trip-mint: #2bc8c4;
  --trip-mint-dark: #078f96;
  --trip-mint-soft: #e8fbf8;
  --trip-cream: #fff7e8;
  --trip-sun: #ffd966;
  --trip-coral: #ff7a5c;
  --trip-ink: #15333c;
  --trip-muted: #5a747b;
  background:
    radial-gradient(circle at 16% 0%, rgba(43, 200, 196, 0.2), transparent 28%),
    linear-gradient(180deg, #f2fffd 0%, #fffefa 42%, #fff6e6 100%);
  color: var(--trip-ink);
}

body.landing-only-page .landing-only-header {
  color: var(--trip-ink);
  background: rgba(255, 255, 255, 0.92);
  border-bottom: 1px solid rgba(43, 200, 196, 0.2);
  box-shadow: 0 14px 36px rgba(11, 94, 96, 0.08);
}

body.landing-only-page .landing-language-menu button,
body.landing-only-page .landing-menu-toggle {
  color: var(--trip-ink);
  background: rgba(255, 255, 255, 0.92);
  border-color: rgba(43, 200, 196, 0.28);
  box-shadow: 0 10px 26px rgba(11, 94, 96, 0.1);
}

body.landing-only-page .landing-menu-toggle span {
  background: var(--trip-ink);
}

body.landing-only-page .tripbusan-landing-hero {
  background:
    radial-gradient(circle at 84% 20%, rgba(255, 217, 102, 0.5), transparent 0 18%, transparent 30%),
    linear-gradient(145deg, #24c6c0 0%, #78ece4 45%, #fff1bf 100%);
}

body.landing-only-page .tripbusan-landing-hero.has-video .hero-background-video {
  opacity: 0.55;
  filter: saturate(1.15) brightness(1.12);
}

body.landing-only-page .hero-overlay {
  background:
    linear-gradient(180deg, rgba(2, 52, 61, 0.16), rgba(2, 52, 61, 0.34)),
    linear-gradient(90deg, rgba(255, 255, 255, 0.38), rgba(255, 255, 255, 0.02));
}

body.landing-only-page .landing-hero-copy .eyebrow {
  color: #fff7c8;
  text-shadow: 0 2px 14px rgba(10, 67, 73, 0.38);
}

body.landing-only-page .landing-hero-copy h1,
body.landing-only-page .hero-main-message {
  color: #ffffff;
  text-shadow: 0 12px 38px rgba(8, 64, 70, 0.34);
}

body.landing-only-page .hero-promise-grid span {
  color: var(--trip-ink);
  background: rgba(255, 255, 255, 0.9);
  border-color: rgba(255, 255, 255, 0.72);
  box-shadow: 0 12px 28px rgba(8, 82, 88, 0.12);
}

body.landing-only-page .hero-promise-action {
  color: var(--trip-ink);
  background: rgba(255, 255, 255, 0.9);
  border-color: rgba(255, 255, 255, 0.72);
  box-shadow: 0 12px 28px rgba(8, 82, 88, 0.12);
}

body.landing-only-page .landing-start-booking-button {
  color: #ffffff;
  background: linear-gradient(135deg, var(--trip-coral), #ff9b68);
  box-shadow: 0 16px 36px rgba(255, 122, 92, 0.32);
}

body.landing-only-page .landing-scroll-button {
  color: var(--trip-ink);
  background: #ffffff;
  border: 1px solid rgba(43, 200, 196, 0.22);
}

body.landing-only-page .landing-menu-card {
  color: var(--trip-ink);
  background:
    radial-gradient(circle at 18% 18%, rgba(255, 255, 255, 0.72), transparent 0 18%, transparent 36%),
    linear-gradient(145deg, #ffffff 0%, #e8fbf8 58%, #d4f8f4 100%);
  border: 1px solid rgba(43, 200, 196, 0.28);
  box-shadow: 0 16px 36px rgba(10, 103, 107, 0.1);
}

body.landing-only-page .landing-menu-card::after {
  color: var(--trip-ink);
  background: var(--trip-sun);
  box-shadow: 0 10px 24px rgba(255, 217, 102, 0.28);
}

body.landing-only-page .landing-menu-card span {
  color: var(--trip-mint-dark);
}

body.landing-only-page .landing-menu-card small {
  color: var(--trip-muted);
}

body.landing-only-page .traveler-explore-section {
  background:
    radial-gradient(circle at 92% 16%, rgba(255, 217, 102, 0.24), transparent 26%),
    linear-gradient(135deg, #ffffff, #f2fffd);
  border-color: rgba(43, 200, 196, 0.24);
  box-shadow: 0 18px 42px rgba(10, 103, 107, 0.08);
}

body.landing-only-page .home-explore-image-cta {
  color: var(--trip-ink);
  background:
    radial-gradient(circle at 84% 24%, rgba(255, 217, 102, 0.6), transparent 0 18%, transparent 32%),
    radial-gradient(circle at 18% 72%, rgba(43, 200, 196, 0.36), transparent 0 22%, transparent 34%),
    linear-gradient(135deg, #ffffff, #e8fbf8 64%, #fff3c9);
  border: 1px solid rgba(43, 200, 196, 0.26);
  box-shadow: 0 18px 44px rgba(10, 103, 107, 0.12);
}

body.landing-only-page .home-explore-image-cta::before {
  opacity: 0.18;
}

body.landing-only-page .home-explore-image-cta::after {
  color: #ffffff;
  background: var(--trip-mint-dark);
}

body.landing-only-page .home-explore-image-cta span {
  color: var(--trip-mint-dark);
  background: rgba(43, 200, 196, 0.14);
}

body.landing-only-page .home-explore-image-cta small {
  color: var(--trip-muted);
}

body.landing-only-page .home-pay-cancel-grid article,
body.landing-only-page .landing-final-section {
  background:
    radial-gradient(circle at 92% 16%, rgba(43, 200, 196, 0.14), transparent 28%),
    #ffffff;
  border-color: rgba(43, 200, 196, 0.2);
  box-shadow: 0 18px 42px rgba(10, 103, 107, 0.08);
}

body.landing-only-page .eyebrow {
  color: var(--trip-mint-dark);
}

body.landing-only-page .section-lead,
body.landing-only-page .landing-section-heading p:not(.eyebrow),
body.landing-only-page .home-pay-cancel-grid p,
body.landing-only-page .landing-final-section p {
  color: var(--trip-muted);
}

@media (max-width: 700px) {
  body.landing-only-page .landing-menu-card-grid.home-service-grid .landing-menu-card {
    background:
      radial-gradient(circle at 20% 18%, rgba(255, 255, 255, 0.8), transparent 0 18%, transparent 34%),
      linear-gradient(145deg, #ffffff, #e8fbf8);
  }

  body.landing-only-page .hero-promise-grid span {
    min-height: 46px;
  }

  body.landing-only-page .hero-promise-action {
    min-height: 46px;
  }
}

.taxi-conversion-hero {
  max-width: 1040px;
  margin: 0 auto;
  padding: clamp(30px, 6vw, 72px) 20px 14px;
}

.taxi-conversion-hero h1 {
  max-width: 760px;
  margin: 4px 0 12px;
  font-size: clamp(2.4rem, 8vw, 5.6rem);
  line-height: 0.95;
  letter-spacing: -0.075em;
}

.taxi-conversion-hero p:not(.eyebrow) {
  max-width: 720px;
  color: #486673;
  font-size: 1.05rem;
  line-height: 1.55;
}

.booking-benefit-strip.compact {
  justify-content: flex-start;
  margin-top: 18px;
}

.taxi-choice-section,
.taxi-booking-stage {
  max-width: 1040px;
}

.taxi-choice-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.taxi-choice-card {
  cursor: pointer;
  display: grid;
  gap: 10px;
  min-height: 240px;
  padding: 22px;
  border: 1px solid #cfe0e0;
  border-radius: 28px;
  background:
    radial-gradient(circle at 85% 14%, rgba(255, 211, 100, 0.26), transparent 34%),
    linear-gradient(160deg, #ffffff, #effafa);
  color: #14313b;
  text-align: left;
  box-shadow: 0 18px 42px rgba(17, 66, 70, 0.09);
  transition: transform 0.18s ease, border-color 0.18s ease, background 0.18s ease;
}

.taxi-choice-card:hover,
.taxi-choice-card.active {
  transform: translateY(-3px);
  border-color: #0b7b82;
  background:
    radial-gradient(circle at 82% 12%, rgba(255, 211, 100, 0.25), transparent 34%),
    linear-gradient(145deg, #0b7b82, #062f3c);
  color: #fff;
}

.taxi-choice-card span {
  width: max-content;
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(14, 119, 126, 0.12);
  color: #0c777e;
  font-size: 0.78rem;
  font-weight: 1000;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.taxi-choice-card.active span,
.taxi-choice-card:hover span {
  background: rgba(255, 255, 255, 0.18);
  color: #fff;
}

.taxi-choice-card strong {
  max-width: 300px;
  font-size: clamp(1.45rem, 3vw, 2.3rem);
  line-height: 1.05;
  letter-spacing: -0.05em;
}

.taxi-choice-card small {
  max-width: 280px;
  color: #5d7480;
  font-size: 0.95rem;
  line-height: 1.45;
}

.taxi-choice-card.active small,
.taxi-choice-card:hover small {
  color: rgba(255, 255, 255, 0.82);
}

.taxi-choice-card b {
  align-self: end;
  width: max-content;
  margin-top: 10px;
  padding: 12px 18px;
  border-radius: 999px;
  background: #0b7b82;
  color: #fff;
  font-size: 0.92rem;
}

.taxi-choice-card.active b,
.taxi-choice-card:hover b {
  background: #fff;
  color: #0b5961;
}

.taxi-booking-stage {
  display: grid;
  gap: 14px;
}

.taxi-booking-stage-header h2 {
  margin: 4px 0;
  font-size: clamp(1.8rem, 4vw, 3rem);
  letter-spacing: -0.055em;
}

.taxi-booking-stage-header p:not(.eyebrow) {
  margin: 0;
  color: #5f747b;
}

.taxi-booking-frame {
  width: 100%;
  min-height: 1400px;
  border: 0;
  border-radius: 24px;
  background: #fff;
}

.tour-hour-options,
.contact-channel-options,
.ktx-list-box {
  display: grid;
  gap: 10px;
}

.tour-hour-options {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.contact-channel-options {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.tour-hour-option,
.contact-channel-option {
  cursor: pointer;
  min-height: 56px;
  padding: 13px 14px;
  border: 1px solid #cfe0e0;
  border-radius: 14px;
  background: #fff;
  color: #17323d;
  font-weight: 1000;
}

.tour-hour-option.active,
.contact-channel-option.active {
  border-color: #0b7b82;
  background: #0b7b82;
  color: #fff;
  box-shadow: 0 12px 28px rgba(11, 123, 130, 0.16);
}

.ktx-option-card {
  cursor: pointer;
  display: grid;
  gap: 4px;
  width: 100%;
  padding: 13px 14px;
  border: 1px solid #cfe0e0;
  border-radius: 13px;
  background: #fff;
  color: #17323d;
  text-align: left;
}

.ktx-option-card.selected {
  border-color: #0b7b82;
  outline: 3px solid rgba(11, 123, 130, 0.12);
}

@media (max-width: 760px) {
  .taxi-conversion-hero {
    padding-top: 22px;
  }

  .taxi-choice-grid {
    grid-template-columns: 1fr;
  }

  .taxi-choice-card {
    min-height: 178px;
    padding: 18px;
    border-radius: 22px;
  }

  .taxi-choice-card strong {
    font-size: 1.55rem;
  }

  .taxi-booking-stage {
    padding-inline: 12px;
  }

  .taxi-booking-frame {
    border-radius: 0;
  }

  .tour-hour-options {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .contact-channel-options {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
/* Partner Marketing Center */
.visually-hidden {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0 0 0 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

.partner-content-card {
  display: grid;
  gap: 16px;
}

.partner-content-progress {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 16px;
  border: 1px solid rgba(10, 117, 123, 0.18);
  border-radius: 18px;
  background: #eefafa;
}

.partner-content-progress strong {
  font-size: clamp(1.6rem, 5vw, 2.4rem);
  color: #08747a;
}

.partner-content-progress.is-ready {
  background: #fff7dc;
  border-color: rgba(249, 185, 36, 0.45);
}

.partner-photo-upload-row {
  display: grid;
  grid-template-columns: minmax(140px, 0.7fr) minmax(220px, 1.3fr) auto;
  gap: 12px;
  align-items: end;
}

.partner-photo-preview-grid,
.partner-content-item-list,
.engine-item-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 12px;
}

.partner-photo-preview-grid figure {
  margin: 0;
  border: 1px solid rgba(9, 85, 93, 0.12);
  border-radius: 16px;
  overflow: hidden;
  background: #f7fbfb;
}

.partner-photo-preview-grid img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  display: block;
}

.partner-photo-preview-grid figcaption {
  padding: 7px 9px;
  font-size: 0.78rem;
  color: #5d7178;
}

.partner-photo-preview-grid figcaption span {
  display: block;
  margin-bottom: 6px;
  font-weight: 900;
  color: #0a3d45;
}

.partner-photo-actions {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.partner-photo-actions button,
.partner-photo-actions strong {
  min-height: 28px;
  padding: 5px 8px;
  border-radius: 999px;
  border: 1px solid rgba(8, 113, 122, 0.18);
  background: #f1fbf9;
  color: #075b63;
  font-size: 0.72rem;
  font-weight: 900;
}

.partner-photo-actions button {
  cursor: pointer;
}

.partner-photo-actions button:last-child {
  background: #fff6f3;
  border-color: rgba(196, 67, 39, 0.22);
  color: #a8422c;
}

.partner-content-item textarea,
.engine-item-card textarea {
  width: 100%;
  min-height: 120px;
  resize: vertical;
}

.partner-marketing-settings {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  padding: 16px;
  border: 1px solid rgba(9, 85, 93, 0.12);
  border-radius: 18px;
  background: #f7fbfb;
}

.partner-marketing-settings h3 {
  margin: 0 0 6px;
  font-size: 1rem;
}

.partner-checkbox-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 8px;
}

.partner-checkbox {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 42px;
  padding: 9px 11px;
  border: 1px solid rgba(9, 85, 93, 0.14);
  border-radius: 14px;
  background: #fff;
  font-weight: 700;
}

.google-business-guide-card {
  margin: 14px 0;
  padding: 16px;
  border: 1px solid rgba(9, 85, 93, 0.16);
  border-radius: 18px;
  background: linear-gradient(135deg, #f3fbf9, #fff9e8);
}

.google-business-guide-card h3 {
  margin: 4px 0 8px;
  font-size: 1.12rem;
}

.google-business-permission-steps {
  margin: 10px 0;
  padding-left: 20px;
  color: #284c56;
}

.google-business-permission-steps li + li {
  margin-top: 6px;
}

.compact-field {
  display: grid;
  gap: 6px;
}

.partner-badge {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  min-height: 30px;
  padding: 7px 11px;
  border: 1px solid rgba(9, 85, 93, 0.18);
  border-radius: 999px;
  background: #fff7cf;
  color: #0d5960;
  font-weight: 900;
  font-size: 0.82rem;
  box-shadow: 0 10px 22px rgba(11, 61, 69, 0.12);
}

.explore-card-badge {
  position: absolute;
  top: 12px;
  left: 12px;
  z-index: 3;
  background: rgba(255, 247, 207, 0.95);
}

.detail-badge {
  margin: 8px 0 12px;
}

.premium-mark {
  display: inline-grid;
  place-items: center;
  width: 34px;
  height: 34px;
  margin: 8px 0 12px;
  border: 2px solid #ffcc3d;
  border-radius: 999px;
  color: #0d5960;
  font-size: 0.95rem;
  font-weight: 1000;
  line-height: 1;
  background: linear-gradient(180deg, #fff8d9, #ffd85f);
  box-shadow: 0 8px 18px rgba(11, 61, 69, 0.14);
}

.explore-card-badge.premium-mark {
  top: 12px;
  left: 12px;
  width: 32px;
  height: 32px;
  margin: 0;
  padding: 0;
  z-index: 4;
  font-size: 0.9rem;
}

.coupon-card-badge + .explore-card-badge.premium-mark,
.explore-card-badge.premium-mark + .coupon-card-badge {
  top: 50px;
}

.qr-stand-status-line,
.admin-qr-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.qr-stand-status-line {
  margin: 16px 0;
}

.badge-benefit-list {
  display: grid;
  gap: 10px;
  margin: 14px 0;
}

.badge-benefit-list p {
  margin: 0;
  padding: 12px 14px;
  border: 1px solid rgba(9, 85, 93, 0.16);
  border-radius: 14px;
  background: #f7fbfb;
  color: #284c56;
}

@media (max-width: 720px) {
  .partner-photo-upload-row {
    grid-template-columns: 1fr;
  }

  .partner-marketing-settings {
    grid-template-columns: 1fr;
  }
}

/* Explore Busan mobile detail: Baemin-style, action-first layout */
.explore-mobile-detail-page {
  background: #f5fbfa;
  padding-bottom: 82px;
}

.explore-mobile-detail-page main {
  width: min(100%, 760px);
  margin: 0 auto;
  padding: 0 14px 92px;
}

.explore-mobile-detail-page .site-header {
  position: sticky;
  top: 0;
  z-index: 70;
  background: rgba(255, 255, 255, 0.96);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(9, 85, 93, 0.1);
}

.explore-mobile-detail-page .site-header nav {
  display: none;
}

.explore-mobile-detail-page .tripbusan-language-switcher {
  position: fixed;
  top: 10px;
  right: 12px;
  z-index: 120;
}

.explore-mobile-detail-page .tripbusan-language-button {
  min-height: 38px;
  padding: 7px 10px;
  border: 1px solid rgba(9, 85, 93, 0.14);
  border-radius: 999px;
  background: #fff;
  color: #0b3338;
  box-shadow: 0 8px 20px rgba(10, 62, 68, 0.12);
}

.explore-mobile-detail-page .tripbusan-language-menu {
  right: 0;
  left: auto;
  max-height: min(72vh, 420px);
  overflow-y: auto;
}

.explore-mobile-hero {
  position: relative;
  margin: 14px auto 16px;
}

.explore-hero-photo-button {
  display: block;
  width: 100%;
  padding: 0;
  border: 0;
  border-radius: 26px;
  overflow: hidden;
  background: #e6f2f1;
  cursor: pointer;
}

.explore-mobile-hero .explore-hero-photo {
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1;
  max-height: 520px;
  object-fit: cover;
}

.explore-hero-photo-count {
  position: absolute;
  top: 14px;
  right: 14px;
  z-index: 4;
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 0 11px;
  border-radius: 999px;
  color: #fff;
  background: rgba(8, 38, 45, 0.68);
  font-size: 0.88rem;
  font-weight: 950;
  line-height: 1;
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.16);
  backdrop-filter: blur(8px);
}

.explore-detail-heart {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border: 0;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.94);
  color: #0b3338;
  font-size: 1.55rem;
  font-weight: 950;
  box-shadow: 0 10px 26px rgba(12, 56, 62, 0.18);
}

.explore-hero-top-actions {
  position: absolute;
  top: 14px;
  left: 14px;
  z-index: 4;
  display: flex;
  gap: 8px;
}

.explore-detail-share {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border: 0;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.94);
  color: #0b3338;
  font-size: 1.45rem;
  font-weight: 950;
  box-shadow: 0 10px 26px rgba(12, 56, 62, 0.18);
}

.hero-photo-nav {
  position: absolute;
  top: min(42vw, 245px);
  z-index: 3;
  display: grid;
  width: 52px;
  height: 52px;
  place-items: center;
  border: 0;
  border-radius: 999px;
  color: #fff;
  font-size: 2.3rem;
  font-weight: 950;
  line-height: 1;
  background: rgba(8, 48, 54, 0.62);
  box-shadow: 0 12px 26px rgba(0, 0, 0, 0.22);
}

.hero-photo-prev {
  left: 12px;
}

.hero-photo-next {
  right: 12px;
}

.explore-detail-heart.is-saved {
  background: #ff6b6b;
  color: #fff;
}

.explore-mobile-title-card {
  position: relative;
  z-index: 2;
  margin: -16px 10px 0;
  padding: 16px;
  border: 1px solid rgba(9, 85, 93, 0.12);
  border-radius: 24px;
  background: #fff;
  box-shadow: 0 18px 42px rgba(10, 62, 68, 0.14);
}

.explore-mobile-title-card h1 {
  margin: 12px 0 8px;
  max-width: 100%;
  font-size: clamp(1.45rem, 6.2vw, 2rem);
  line-height: 1.16;
  letter-spacing: 0;
  overflow-wrap: anywhere;
  word-break: keep-all;
}

.explore-mobile-title-card p:not(.eyebrow) {
  margin: 0;
  color: #4e6b72;
  line-height: 1.45;
}

.explore-mobile-title-card .place-intro-text {
  max-width: 31em;
  margin-top: 12px;
  color: #405f66;
  font-size: clamp(0.98rem, 4.05vw, 1.12rem);
  font-weight: 620;
  line-height: 1.64;
  letter-spacing: 0;
  white-space: pre-line;
  word-break: keep-all;
  overflow-wrap: anywhere;
}

.detail-google-trust-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 2px 0 10px;
}

.detail-rating-stack {
  display: inline-flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 2px;
  padding: 8px 11px;
  border-radius: 14px;
  background: #fff7df;
  color: #102f3a;
  box-shadow: inset 0 0 0 1px rgba(255, 183, 49, 0.24);
}

.detail-rating-stack b {
  font-size: 1rem;
  font-weight: 950;
  line-height: 1;
}

.detail-rating-stack small {
  color: #12646b;
  font-size: 0.78rem;
  font-weight: 900;
  line-height: 1.1;
  white-space: nowrap;
}

.mobile-status-row {
  display: flex;
  gap: 7px;
  overflow-x: auto;
  margin-top: 13px;
  padding-bottom: 2px;
  scrollbar-width: none;
}

.mobile-status-row::-webkit-scrollbar {
  display: none;
}

.mobile-status-row span {
  flex: 0 0 auto;
  padding: 7px 10px;
  border-radius: 999px;
  background: #eef7f6;
  color: #24565e;
  font-size: 0.78rem;
  font-weight: 850;
  white-space: nowrap;
}

.mobile-status-row .open-status.open {
  background: #e4fff2;
  color: #087147;
}

.mobile-status-row .open-status.closed,
.mobile-status-row .open-status.unknown,
.mobile-status-row .open-status.break {
  background: #fff0e8;
  color: #a34415;
}

.mobile-status-row .open-status.closing-soon,
.mobile-status-row .open-status.opening-soon {
  background: #fff7d8;
  color: #7b5400;
}

.mobile-detail-section,
.reservation-request-section {
  width: min(100%, 760px);
  margin: 12px auto;
}

.mobile-action-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}

.transport-four-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.optional-contact-grid {
  margin-top: 10px;
}

.mobile-action-grid.primary-actions {
  grid-template-columns: 1fr 1fr;
}

.mobile-action-grid.primary-actions .primary-cta {
  grid-column: 1 / -1;
}

.mobile-action-grid .primary-cta,
.mobile-action-grid .secondary-link,
.mobile-action-grid .taxi-action-button {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 50px;
  padding: 12px 14px;
  border-radius: 16px;
  text-align: center;
  text-decoration: none;
  font-weight: 950;
}

.copy-location-button {
  border: 1px solid rgba(9, 85, 93, 0.28);
  background: #dff5f3;
  color: #075d66;
  cursor: pointer;
  font: inherit;
  box-shadow: 0 10px 22px rgba(10, 127, 132, 0.12);
}

.mobile-action-grid .primary-cta {
  background: #0a7f84;
  color: #fff;
  box-shadow: 0 12px 26px rgba(10, 127, 132, 0.22);
}

.mobile-action-grid .secondary-link {
  border: 1px solid rgba(9, 85, 93, 0.16);
  background: #fff;
  color: #0b5960;
}

.mobile-action-grid .taxi-action-button.uber {
  background: #111;
  color: #fff;
}

.mobile-action-grid .taxi-action-button.kakao {
  background: #fee500;
  color: #191600;
}

.mobile-action-grid .transport-actions {
  display: contents;
}

.mobile-accordion {
  position: relative;
  border: 1px solid rgba(9, 85, 93, 0.14);
  border-radius: 22px;
  background: #fff;
  overflow: hidden;
  box-shadow: 0 14px 32px rgba(10, 62, 68, 0.08);
}

body.explore-mobile-detail-page .mobile-detail-section .mobile-accordion::before {
  content: "";
  position: absolute;
  top: 26px;
  left: 20px;
  z-index: 2;
  width: 11px;
  height: 11px;
  border: 3px solid #ffffff;
  border-radius: 999px;
  background: #0a7f84;
  box-shadow: 0 0 0 2px rgba(10, 127, 132, 0.18);
}

body.explore-mobile-detail-page .mobile-detail-section .mobile-accordion summary {
  padding-left: 52px !important;
}

body.explore-mobile-detail-page .mobile-detail-section .mobile-accordion:not([open]) summary,
body.explore-mobile-detail-page .coupon-detail-section .mobile-accordion > summary {
  min-height: 60px !important;
}

body.explore-mobile-detail-page .mobile-detail-section .mobile-accordion summary {
  position: relative;
  align-items: center !important;
  gap: 7px !important;
  justify-content: flex-start !important;
  min-height: 60px !important;
  padding-top: 12px !important;
  padding-right: 62px !important;
  padding-bottom: 12px !important;
  font-size: 1.08rem !important;
  line-height: 1.08 !important;
}

body.explore-mobile-detail-page .google-review-summary-title {
  flex: 0 0 auto;
  font-size: 1.08rem;
  font-weight: 950;
  line-height: 1.08;
}

body.explore-mobile-detail-page .google-review-summary-meta {
  flex: 0 1 auto;
  min-width: 0;
  overflow: hidden;
  color: #49666d;
  font-size: 0.88rem;
  font-weight: 900;
  line-height: 1.08;
  text-overflow: ellipsis;
  white-space: nowrap;
}

body.explore-mobile-detail-page .mobile-detail-section .mobile-accordion summary::after {
  position: absolute;
  top: 50%;
  right: 18px;
  flex: none;
  margin-left: 0;
  transform: translateY(-50%);
}

.mobile-accordion + .mobile-accordion {
  margin-top: 10px;
}

.mobile-accordion summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 58px;
  padding: 16px 18px 16px 52px;
  color: #0b3338;
  cursor: pointer;
  font-size: 1.08rem;
  font-weight: 950;
  list-style: none;
}

body.explore-mobile-detail-page .mobile-detail-section {
  position: relative;
}

body.explore-mobile-detail-page .place-review-section {
  width: 100%;
  margin-right: 0;
  margin-left: 0;
}

body.explore-mobile-detail-page .place-review-section .google-review-visible-block {
  width: 100%;
  margin: 0;
}

body.explore-mobile-detail-page .place-review-section .google-review-visible-block > summary {
  width: calc(100% - 31px) !important;
  margin: 0 16px !important;
}

body.explore-mobile-detail-page .mobile-detail-section::before {
  content: "";
  position: absolute;
  top: 22px;
  bottom: 22px;
  left: calc(50% - min(380px, 50%) + 20px);
  width: 2px;
  border-radius: 999px;
  background: rgba(10, 127, 132, 0.12);
}

.mobile-accordion summary::-webkit-details-marker {
  display: none;
}

.mobile-accordion summary::after {
  content: "⌄";
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  border-radius: 999px;
  background: #eef7f6;
  color: #0a7f84;
}

.mobile-accordion[open] summary::after {
  transform: translateY(-50%) rotate(180deg);
}

.accordion-body {
  padding: 0 18px 18px;
}

.accordion-body > p {
  margin: 0 0 12px;
  color: #4d6b72;
  line-height: 1.45;
}

.contact-summary-row {
  display: flex;
  align-items: center;
  gap: 8px;
}

.owner-kakao-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  min-height: 30px;
  padding: 5px 10px;
  border-radius: 999px;
  background: #fee500;
  color: #191600;
  font-weight: 900;
  line-height: 1;
  text-decoration: none;
  box-shadow: 0 5px 14px rgba(25, 22, 0, 0.12);
}

.owner-kakao-button span {
  display: inline-grid;
  place-items: center;
  width: 20px;
  height: 20px;
  border-radius: 999px;
  background: #3c1e1e;
  color: #fee500;
  font-size: 11px;
}

.owner-kakao-button strong {
  font-size: 13px;
  letter-spacing: 0;
}

.owner-sns-contact-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  width: 100%;
}

.owner-sns-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  min-height: 38px;
  padding: 7px 9px;
  border-radius: 999px;
  background: #eefafa;
  color: #063f43;
  font-weight: 900;
  line-height: 1;
  text-decoration: none;
  border: 1px solid rgba(0, 122, 128, 0.14);
  box-shadow: 0 5px 14px rgba(6, 63, 67, 0.08);
}

.owner-sns-button span {
  display: inline-grid;
  place-items: center;
  min-width: 22px;
  height: 22px;
  padding: 0 4px;
  border-radius: 999px;
  background: #0b7f83;
  color: #fff;
  font-size: 11px;
}

.owner-sns-button strong {
  font-size: 13px;
  letter-spacing: 0;
  white-space: nowrap;
}

.owner-sns-summary {
  background: #ecfbfb;
  color: #063f43;
  border-color: rgba(0, 122, 128, 0.18);
}

.owner-sns-summary span {
  min-width: 30px;
  background: #0b7f83;
  font-size: 10px;
}

.owner-sns-kakao {
  background: #fee500;
  color: #191600;
  border-color: rgba(25, 22, 0, 0.1);
}

.owner-sns-kakao span {
  background: #3c1e1e;
  color: #fee500;
}

.owner-sns-line {
  background: #ecfff2;
  color: #064f25;
}

.owner-sns-line span {
  background: #06c755;
}

.owner-sns-whatsapp {
  background: #eafff3;
  color: #075b34;
}

.owner-sns-whatsapp span {
  background: #25d366;
}

.owner-sns-wechat {
  background: #f0fff0;
  color: #164d1d;
}

.owner-sns-wechat span {
  background: #1aad19;
}

.owner-sns-instagram {
  background: #fff0f6;
  color: #8a164d;
}

.owner-sns-instagram span {
  background: #d62976;
}

.owner-sns-facebook {
  background: #eef5ff;
  color: #0b3f91;
}

.owner-sns-facebook span {
  background: #1877f2;
}

.owner-sns-tiktok {
  background: #f7f7f7;
  color: #111;
}

.owner-sns-tiktok span {
  background: #111;
}

.owner-wechat-dialog {
  position: fixed;
  inset: 0;
  z-index: 1200;
  display: grid;
  align-items: end;
  padding: 18px;
  background: rgba(4, 26, 30, 0.42);
}

.customer-image-preview-dialog {
  touch-action: pan-y;
}

.customer-image-preview-dialog img {
  user-select: none;
  -webkit-user-drag: none;
}

.owner-wechat-dialog[hidden] {
  display: none;
}

.owner-wechat-dialog-panel {
  position: relative;
  display: grid;
  gap: 12px;
  width: min(100%, 420px);
  margin: 0 auto;
  padding: 22px;
  border-radius: 22px;
  background: #fff;
  color: #09343a;
  box-shadow: 0 22px 60px rgba(4, 26, 30, 0.24);
}

.owner-wechat-dialog-panel strong {
  font-size: 22px;
}

.owner-wechat-dialog-panel p {
  margin: 0;
  color: #4d6b72;
  line-height: 1.45;
}

.owner-wechat-dialog-panel code {
  display: block;
  padding: 12px;
  border-radius: 12px;
  background: #edf8f7;
  color: #063f43;
  font-size: 16px;
  font-weight: 900;
  overflow-wrap: anywhere;
}

.owner-wechat-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.owner-wechat-actions a,
.owner-wechat-actions button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 8px 10px;
  border: 0;
  border-radius: 999px;
  background: #0b7f83;
  color: #fff;
  font: inherit;
  font-weight: 900;
  text-decoration: none;
  text-align: center;
}

.owner-wechat-close {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 34px;
  height: 34px;
  border: 0;
  border-radius: 999px;
  background: #eef7f6;
  color: #0b5961;
  font-size: 24px;
  line-height: 1;
}

.phone-contact-cell {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
}

.owner-phone-link {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  color: #073f45;
  font-weight: 950;
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-underline-offset: 4px;
  letter-spacing: 0;
}

.owner-phone-link[href] {
  cursor: pointer;
}

.owner-phone-link[href]:active {
  color: #007f7c;
}

.explore-photo-strip {
  gap: 10px;
  padding-bottom: 6px;
}

.explore-photo-strip img,
.explore-photo-strip .photo-placeholder {
  flex: 0 0 min(74vw, 260px);
  width: min(74vw, 260px);
  height: auto;
  aspect-ratio: 1 / 1;
  border-radius: 18px;
  object-fit: cover;
}

.exploration-info-list {
  display: grid;
  gap: 10px;
  margin: 0 0 14px;
}

.exploration-info-list div {
  display: grid;
  grid-template-columns: 76px minmax(0, 1fr);
  gap: 10px;
  padding: 10px 0;
  border-bottom: 1px solid rgba(9, 85, 93, 0.09);
}

.exploration-info-list dt {
  color: #6e858a;
  font-size: 0.85rem;
  font-weight: 900;
}

.exploration-info-list dd {
  margin: 0;
  color: #0f3338;
  font-weight: 800;
}

.reservation-request-section {
  padding: 18px;
  border: 1px solid rgba(9, 85, 93, 0.14);
  border-radius: 22px;
  background: #fff;
  box-shadow: 0 14px 32px rgba(10, 62, 68, 0.08);
}

.reservation-request-section h2 {
  margin: 6px 0 8px;
  font-size: clamp(1.45rem, 6vw, 2.25rem);
  line-height: 1.06;
}

.reservation-request-section > p {
  color: #526f76;
  line-height: 1.45;
}

.reservation-menu-row {
  grid-template-columns: 52px minmax(0, 1fr) auto;
  gap: 7px;
  padding: 7px;
  border-radius: 14px;
}

.reservation-menu-row img,
.reservation-menu-row .compact-menu-photo-placeholder {
  width: 52px;
  height: 52px;
  border-radius: 10px;
}

.compact-explore-reservation-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.compact-explore-reservation-grid label {
  min-width: 0;
  font-size: 0.82rem;
}

.compact-explore-reservation-grid input,
.compact-explore-reservation-grid select {
  min-height: 42px;
  padding: 9px 10px;
}

.review-write-link {
  margin-top: 12px;
}

.mobile-bottom-nav {
  position: fixed;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 90;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 4px;
  padding: 8px 8px calc(8px + env(safe-area-inset-bottom));
  border-top: 1px solid rgba(9, 85, 93, 0.12);
  background: rgba(255, 255, 255, 0.98);
  box-shadow: 0 -14px 28px rgba(9, 49, 55, 0.12);
}

.mobile-bottom-nav a {
  display: grid;
  gap: 3px;
  justify-items: center;
  align-items: center;
  min-height: 46px;
  border-radius: 14px;
  color: #24565e;
  text-decoration: none;
  font-size: 0.72rem;
  font-weight: 900;
}

.mobile-bottom-nav a:hover,
.mobile-bottom-nav a:focus {
  background: #eaf7f5;
  color: #0a7f84;
}

.mobile-bottom-nav span {
  font-size: 1.15rem;
  line-height: 1;
}

@media (min-width: 761px) {
  .explore-mobile-detail-page main {
    width: min(760px, calc(100% - 48px));
    padding-top: 18px;
  }

  .explore-mobile-detail-page .site-header nav {
    display: flex;
  }

  body.explore-mobile-detail-page .explore-mobile-hero,
  body.explore-mobile-detail-page main > .mobile-detail-section,
  body.explore-mobile-detail-page main > .content-section,
  body.explore-mobile-detail-page main > .reservation-request-section {
    width: 100%;
    max-width: none;
    margin-right: 0;
    margin-left: 0;
    box-sizing: border-box;
  }

  .explore-mobile-hero .explore-hero-photo {
    aspect-ratio: 16 / 10;
  }

  body.explore-mobile-detail-page .explore-mobile-title-card {
    margin-right: 0;
    margin-left: 0;
  }

  body.explore-mobile-detail-page .mobile-accordion,
  body.explore-mobile-detail-page .reservation-request-section,
  body.explore-mobile-detail-page .content-section {
    width: 100%;
    box-sizing: border-box;
  }

  body.explore-mobile-detail-page .place-review-section,
  body.explore-mobile-detail-page .place-review-section .google-review-visible-block,
  body.explore-mobile-detail-page .place-review-section .google-review-visible-block > summary {
    width: 100% !important;
    margin-right: 0 !important;
    margin-left: 0 !important;
  }

  body.explore-mobile-detail-page .place-travel-metrics {
    width: 100% !important;
    margin-inline: 0 !important;
  }

  body.explore-mobile-detail-page .review-slider {
    margin-right: 0 !important;
    padding-right: 0 !important;
  }

  .mobile-bottom-nav {
    right: 50%;
    left: auto;
    width: min(760px, 100%);
    transform: translateX(50%);
    border-radius: 22px 22px 0 0;
  }

  .tripbusan-business-type-strip {
    display: none !important;
  }
}

@media (max-width: 760px) {
  .tripbusan-business-type-strip {
    bottom: calc(82px + env(safe-area-inset-bottom));
  }
}
/* Partner quick application */
.simple-partner-hero h1 {
  max-width: 720px;
}

.simple-partner-card {
  max-width: 780px;
}

.partner-inquiry-result {
  margin-top: 18px;
  padding: 18px;
  border-radius: 18px;
  font-weight: 800;
}

.partner-inquiry-result p {
  margin: 8px 0 0;
  color: var(--muted);
  font-weight: 700;
}

.partner-inquiry-result.success {
  border: 1px solid rgba(0, 128, 118, 0.25);
  background: #ecfbf8;
  color: #004f4a;
}

.partner-inquiry-result.error {
  border: 1px solid rgba(210, 75, 75, 0.25);
  background: #fff0f0;
  color: #9a2525;
}

.partner-google-autofill {
  display: grid;
  gap: 14px;
}

.kakao-channel-card {
  display: grid;
  gap: 10px;
  padding: 16px;
  border: 1px solid rgba(19, 93, 98, 0.18);
  border-radius: 18px;
  background: #fffdf0;
}

.kakao-channel-card strong {
  font-size: 1.05rem;
}

.kakao-channel-card span {
  color: #557079;
  font-weight: 800;
}

.google-autoreg-preview {
  display: grid;
  gap: 12px;
  padding: 16px;
  border: 1px solid rgba(19, 93, 98, 0.2);
  border-radius: 18px;
  background: rgba(237, 250, 248, 0.9);
}

.autoreg-preview-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.autoreg-preview-head strong {
  font-size: 1.15rem;
}

.autoreg-preview-head span {
  padding: 5px 9px;
  border-radius: 999px;
  background: #fff7c4;
  color: #17323a;
  font-size: 0.78rem;
  font-weight: 800;
}

.google-autoreg-preview dl {
  display: grid;
  gap: 8px;
  margin: 0;
}

.google-autoreg-preview dl div {
  display: grid;
  grid-template-columns: 86px 1fr;
  gap: 10px;
}

.google-autoreg-preview dt {
  color: #557079;
  font-weight: 800;
}

.google-autoreg-preview dd {
  margin: 0;
  color: #17323a;
}

.partner-join-page {
  min-height: 100vh;
  color: #102f39;
  background: linear-gradient(180deg, rgba(225, 246, 245, 0.9), rgba(249, 252, 250, 0.98) 42%), #f8fbfa;
}

.partner-join-header {
  position: sticky;
  top: 0;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 14px max(18px, env(safe-area-inset-left)) 12px;
  border-bottom: 1px solid rgba(14, 78, 88, 0.1);
  background: rgba(248, 252, 251, 0.92);
  backdrop-filter: blur(14px);
}

.partner-join-header .logo {
  color: #0d5f68;
  font-size: 1.05rem;
  font-weight: 950;
  text-decoration: none;
  letter-spacing: 0.08em;
}

.partner-login-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 0 14px;
  border: 1px solid rgba(14, 78, 88, 0.18);
  border-radius: 999px;
  color: #12333d;
  background: #fff;
  font-size: 0.9rem;
  font-weight: 900;
  text-decoration: none;
}

.partner-join-main {
  width: min(760px, 100%);
  margin: 0 auto;
  padding: 22px 16px 42px;
}

.partner-join-hero {
  display: grid;
  gap: 14px;
  padding: 24px 2px 18px;
}

.partner-join-hero span,
.join-step-label {
  width: fit-content;
  padding: 7px 10px;
  border-radius: 999px;
  color: #075d66;
  background: #dff5f3;
  font-size: 0.75rem;
  font-weight: 950;
  letter-spacing: 0.08em;
}

body.partner-join-page .partner-join-hero h1 {
  margin: 0;
  color: #102d37;
  font-size: 34px;
  line-height: 1.08;
  letter-spacing: 0;
  word-break: keep-all;
}

.partner-join-hero p {
  margin: 0;
  color: #506a73;
  font-size: 1rem;
  font-weight: 750;
  line-height: 1.55;
}

.partner-join-benefits {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin-top: 4px;
}

.partner-join-benefits strong {
  display: grid;
  min-height: 56px;
  place-items: center;
  padding: 9px;
  border: 1px solid rgba(14, 78, 88, 0.13);
  border-radius: 8px;
  color: #12333d;
  background: rgba(255, 255, 255, 0.9);
  font-size: 0.82rem;
  line-height: 1.25;
  text-align: center;
  box-shadow: 0 10px 28px rgba(8, 55, 65, 0.06);
}

.partner-join-card,
.partner-join-note {
  display: grid;
  gap: 16px;
  margin-top: 16px;
  padding: 18px;
  border: 1px solid rgba(14, 78, 88, 0.14);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 18px 38px rgba(8, 55, 65, 0.08);
}

.partner-join-card h2 {
  margin: 0;
  color: #102d37;
  font-size: 1.55rem;
  line-height: 1.08;
  letter-spacing: 0;
}

.partner-google-autofill,
.partner-join-form {
  display: grid;
  gap: 12px;
}

.partner-join-card label {
  display: grid;
  gap: 7px;
  color: #17343e;
  font-size: 0.9rem;
  font-weight: 900;
}

.partner-join-card input,
.partner-join-card textarea {
  width: 100%;
  min-height: 50px;
  padding: 13px 14px;
  border: 1px solid #c9d9dd;
  border-radius: 8px;
  color: #102f39;
  background: #fbfefd;
  font: inherit;
  font-size: 1rem;
}

.partner-join-card textarea {
  min-height: 84px;
  resize: vertical;
}

.partner-join-actions {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 8px;
}

.partner-join-actions button,
.partner-submit-button {
  width: 100%;
  min-height: 50px;
  border-radius: 8px;
  font-weight: 950;
}

body.partner-join-page .partner-join-actions .primary-button,
body.partner-join-page .partner-submit-button {
  border: 1px solid #0b6d75 !important;
  color: #fff !important;
  background: #0b6d75 !important;
}

body.partner-join-page .partner-join-actions .secondary-button {
  border: 1px solid #bfd3d7 !important;
  color: #12333d !important;
  background: #f7fcfb !important;
}

.partner-submit-button {
  margin-top: 2px;
  font-size: 1.02rem;
}

.partner-refresh-button {
  justify-self: start;
  min-height: 34px;
  padding: 0;
  color: #0c6670;
  background: transparent;
}

.partner-join-note {
  margin-bottom: 20px;
  background: #f3fbfa;
}

.partner-join-note strong {
  color: #0d5f68;
}

.partner-join-note p {
  margin: 0;
  color: #536d76;
  line-height: 1.65;
}

.partner-join-page .partner-inquiry-result,
.partner-join-page .google-autoreg-preview {
  border-radius: 8px;
}

@media (min-width: 800px) {
  .partner-join-main {
    padding-top: 38px;
  }

  body.partner-join-page .partner-join-hero h1 {
    font-size: 64px;
  }

  .partner-join-card {
    padding: 24px;
  }
}

@media (max-width: 420px) {
  .partner-join-main {
    padding-inline: 12px;
  }

  .partner-join-benefits {
    grid-template-columns: 1fr;
  }

  .partner-join-benefits strong {
    min-height: 42px;
  }

  .partner-join-actions {
    grid-template-columns: 1fr;
  }

  body.partner-join-page .partner-join-hero h1 {
    font-size: 32px;
  }
}
/* TripTalk community page */
.triptalk-main {
  width: min(980px, calc(100% - 28px));
  margin: 0 auto;
  padding: 24px 0 110px;
}

.triptalk-community-hero,
.triptalk-live-panel,
.triptalk-board {
  border: 1px solid rgba(11, 82, 86, 0.14);
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.82);
  box-shadow: 0 18px 42px rgba(0, 55, 58, 0.08);
}

.triptalk-community-hero {
  padding: 30px;
  background:
    radial-gradient(circle at top right, rgba(42, 197, 188, 0.22), transparent 34%),
    linear-gradient(135deg, #f5fffb, #ffffff);
}

.triptalk-community-hero h1 {
  max-width: 760px;
  margin: 8px 0 12px;
  font-size: clamp(2.2rem, 7vw, 5.8rem);
  line-height: 0.95;
  letter-spacing: -0.08em;
}

.triptalk-community-hero p {
  max-width: 680px;
  color: #4d6870;
  font-size: 1.04rem;
  line-height: 1.65;
}

.triptalk-live-panel,
.triptalk-board {
  margin-top: 18px;
  padding: 22px;
}

.section-heading-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}

.section-heading-row h1,
.section-heading-row h2 {
  margin: 4px 0 0;
  font-size: clamp(1.6rem, 5vw, 3rem);
  line-height: 1.02;
  letter-spacing: 0;
  word-break: keep-all;
}

.text-link {
  color: #06777b;
  font-weight: 900;
  text-decoration: none;
}

.triptalk-live-list {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-top: 16px;
}

.triptalk-clean-main {
  display: grid;
  gap: 18px;
}

.triptalk-blog-main {
  margin-top: 0;
}

.triptalk-blog-main .section-heading-row {
  margin-bottom: 16px;
}

.section-subcopy {
  max-width: 680px;
  margin: 8px 0 0;
  color: #526d73;
  line-height: 1.55;
}

.triptalk-blog-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.triptalk-blog-card {
  overflow: hidden;
  border: 1px solid rgba(4, 97, 99, 0.12);
  border-radius: 18px;
  background: #fff;
  box-shadow: 0 14px 30px rgba(0, 55, 58, 0.06);
}

.triptalk-blog-card a {
  display: grid;
  min-height: 100%;
  color: inherit;
  text-decoration: none;
}

.triptalk-blog-card img {
  display: block;
  width: 100%;
  height: 190px;
  object-fit: cover;
}

.triptalk-blog-card-copy {
  display: grid;
  gap: 8px;
  padding: 15px 16px 16px;
}

.triptalk-blog-card-copy h3 {
  margin: 0;
  color: #12333b;
  font-size: 1.18rem;
  line-height: 1.25;
  letter-spacing: 0;
  word-break: keep-all;
}

.triptalk-blog-card-copy p:not(.eyebrow) {
  display: -webkit-box;
  margin: 0;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  color: #526d73;
  line-height: 1.5;
}

.triptalk-blog-card.featured {
  grid-column: span 2;
}

.triptalk-blog-card.featured a {
  grid-template-columns: minmax(0, 1.12fr) minmax(280px, 0.88fr);
}

.triptalk-blog-card.featured img {
  height: 100%;
  min-height: 310px;
}

.triptalk-blog-card.featured .triptalk-blog-card-copy {
  align-content: center;
  padding: 24px;
}

.triptalk-blog-card.featured h3 {
  font-size: 1.7rem;
  line-height: 1.18;
}

.triptalk-qna-board {
  background: rgba(255, 255, 255, 0.92);
}

.triptalk-qna-list {
  display: grid;
  margin-top: 14px;
  border-top: 1px solid rgba(4, 97, 99, 0.14);
}

.triptalk-qna-item {
  border-bottom: 1px solid rgba(4, 97, 99, 0.12);
}

.triptalk-qna-item a {
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  padding: 15px 2px;
  color: inherit;
  text-decoration: none;
}

.triptalk-qna-number {
  color: #7a9698;
  font-size: 0.86rem;
  font-weight: 900;
}

.triptalk-qna-item strong {
  overflow: hidden;
  color: #12333b;
  font-size: 1rem;
  line-height: 1.35;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.triptalk-qna-item a > span:last-child {
  border: 1px solid rgba(4, 97, 99, 0.14);
  border-radius: 999px;
  padding: 7px 10px;
  color: #06777b;
  font-size: 0.78rem;
  font-weight: 900;
}

.triptalk-live-card,
.triptalk-card a {
  display: block;
  color: inherit;
  text-decoration: none;
}

.triptalk-live-card {
  overflow: hidden;
  min-height: 156px;
  padding: 0 0 18px;
  border-radius: 22px;
  background: #073f45;
  color: #fff;
}

.triptalk-live-card img,
.triptalk-card-image,
.triptalk-article-cover,
.triptalk-article-visual img {
  display: block;
  width: 100%;
  object-fit: cover;
}

.triptalk-live-card img {
  height: 132px;
}

.triptalk-live-card span,
.triptalk-live-card strong,
.triptalk-live-card small {
  margin-left: 16px;
  margin-right: 16px;
}

.triptalk-live-card span,
.triptalk-card-action {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.16);
  font-size: 0.76rem;
  font-weight: 900;
}

.triptalk-live-card strong {
  display: block;
  margin-top: 14px;
  font-size: 1.08rem;
  line-height: 1.18;
}

.triptalk-live-card small {
  display: block;
  margin-top: 10px;
  color: rgba(255, 255, 255, 0.78);
  line-height: 1.45;
}

.triptalk-tabs {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding-bottom: 4px;
}

.triptalk-section-tabs {
  position: sticky;
  top: 0;
  z-index: 8;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin: 0 0 16px;
  padding: 10px;
  border: 1px solid rgba(4, 97, 99, 0.12);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 12px 30px rgba(0, 55, 58, 0.08);
  backdrop-filter: blur(10px);
}

.triptalk-section-tabs a {
  display: inline-flex;
  min-height: 48px;
  align-items: center;
  justify-content: center;
  gap: 8px;
  border: 1px solid rgba(4, 97, 99, 0.16);
  border-radius: 14px;
  background: #fff;
  color: #12333b;
  font-size: 0.98rem;
  font-weight: 900;
  text-decoration: none;
}

.triptalk-section-tabs a strong {
  display: inline-grid;
  min-width: 28px;
  min-height: 24px;
  align-items: center;
  border-radius: 999px;
  background: rgba(4, 97, 99, 0.08);
  color: #06777b;
  font-size: 0.8rem;
  line-height: 1;
}

.triptalk-section-tabs a.active {
  border-color: #073f45;
  background: #073f45;
  color: #fff;
}

.triptalk-section-tabs a.active strong {
  background: rgba(255, 255, 255, 0.18);
  color: #fff;
}

.triptalk-language-switcher {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding: 4px 0 12px;
}

.triptalk-language-switcher a,
.triptalk-language-switcher button {
  flex: 0 0 auto;
  border: 1px solid rgba(4, 97, 99, 0.16);
  border-radius: 999px;
  background: #fff;
  color: #24484e;
  padding: 10px 13px;
  font-size: 0.86rem;
  font-weight: 900;
  text-decoration: none;
}

.triptalk-language-switcher .active,
.triptalk-language-switcher button.active {
  border-color: #073f45;
  background: #073f45;
  color: #fff;
}

.triptalk-tabs button {
  flex: 0 0 auto;
  border: 1px solid rgba(4, 97, 99, 0.16);
  border-radius: 999px;
  background: #fff;
  color: #12333b;
  padding: 11px 16px;
  font-weight: 900;
}

.triptalk-tabs button.active {
  background: #13bdb6;
  border-color: #13bdb6;
  color: #fff;
}

.triptalk-note {
  display: grid;
  gap: 4px;
  margin: 14px 0;
  padding: 14px 16px;
  border-radius: 18px;
  background: #eafbf8;
  color: #224a51;
}

.triptalk-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.triptalk-card {
  overflow: hidden;
  border: 1px solid rgba(4, 97, 99, 0.12);
  border-radius: 22px;
  background: #fff;
  padding: 0 0 18px;
}

.triptalk-card a {
  min-height: 100%;
}

.triptalk-card-image {
  height: 168px;
  margin-bottom: 14px;
}

.triptalk-card .eyebrow,
.triptalk-card h3,
.triptalk-card p,
.triptalk-card-action {
  margin-left: 16px;
  margin-right: 16px;
}

.triptalk-card h3 {
  margin: 8px 0;
  font-size: 1.2rem;
  line-height: 1.14;
}

.triptalk-card p {
  margin: 0 0 16px;
  color: #54707a;
  line-height: 1.5;
}

.triptalk-card-action {
  background: #eef8f6;
  color: #06777b;
}

.triptalk-qna-row {
  padding: 0;
}

.triptalk-qna-row a {
  display: grid;
  min-height: auto;
  gap: 6px;
  padding: 14px 16px;
}

.triptalk-qna-row .eyebrow,
.triptalk-qna-row h3,
.triptalk-qna-row .triptalk-card-action {
  margin-right: 0;
  margin-left: 0;
}

.triptalk-qna-row .eyebrow {
  margin-bottom: 0;
}

.triptalk-qna-row h3 {
  display: -webkit-box;
  margin: 0;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  font-size: 1rem;
  line-height: 1.35;
}

.triptalk-qna-row .triptalk-card-action {
  width: fit-content;
  margin-top: 2px;
}

.triptalk-article-cover {
  height: min(58vh, 430px);
  border-radius: 24px;
  margin: 0 0 18px;
}

.triptalk-article h1 {
  font-size: 2.7rem;
  line-height: 1.08;
  letter-spacing: 0;
  word-break: keep-all;
  overflow-wrap: break-word;
}

.triptalk-article .summary {
  font-size: 1.04rem;
  line-height: 1.55;
}

.triptalk-article-visual {
  margin: 22px 0;
}

.triptalk-article-visual img {
  max-height: 360px;
  border-radius: 22px;
}

.triptalk-article-visual figcaption {
  margin-top: 8px;
  color: #60787f;
  font-size: 0.86rem;
  line-height: 1.45;
}

@media (max-width: 720px) {
  .triptalk-main {
    width: min(100% - 20px, 520px);
    padding-top: 10px;
  }

  .triptalk-community-hero,
  .triptalk-live-panel,
  .triptalk-board {
    border-radius: 24px;
    padding: 18px;
  }

  .triptalk-live-list,
  .triptalk-grid,
  .triptalk-blog-grid {
    grid-template-columns: 1fr;
  }

  .triptalk-live-card img,
  .triptalk-card-image {
    height: 190px;
  }

  .triptalk-blog-card.featured {
    grid-column: auto;
  }

  .triptalk-blog-card.featured a {
    grid-template-columns: 1fr;
  }

  .triptalk-blog-card img,
  .triptalk-blog-card.featured img {
    height: 190px;
    min-height: 0;
  }

  .triptalk-blog-card.featured .triptalk-blog-card-copy {
    padding: 15px 16px 16px;
  }

  .triptalk-blog-card.featured h3 {
    font-size: 1.22rem;
    line-height: 1.24;
  }

  .triptalk-qna-item a {
    grid-template-columns: 34px minmax(0, 1fr) auto;
    gap: 8px;
    padding: 14px 0;
  }

  .triptalk-qna-item strong {
    font-size: 0.96rem;
  }

  .triptalk-article {
    padding: 16px;
  }

  .triptalk-article h1 {
    font-size: 2rem;
    line-height: 1.14;
  }

  .triptalk-article-cover {
    height: 230px;
    border-radius: 20px;
  }
}
.coupon-exclusive-badge,
.coupon-card-badge {
  display: inline-grid;
  place-items: center;
  background: #fff7d6;
  color: #6a3f00;
  border: 1px solid #f4c95d;
}

.coupon-card-badge {
  width: 32px;
  height: 32px;
  padding: 0;
  border-radius: 999px;
  font-size: 1rem;
  line-height: 1;
}

.coupon-exclusive-badge.detail-badge {
  width: 34px;
  height: 34px;
  padding: 0;
  border-radius: 999px;
  font-size: 1.05rem;
  line-height: 1;
}

.solo-dining-card-badge,
.solo-dining-detail-badge,
.solo-dining-admin-badge {
  border-color: #e0b86d;
  background: #fff1d6;
  color: #7a4a00;
}

.solo-dining-card-badge {
  top: 52px;
  padding: 7px 12px;
}

.solo-dining-detail-badge {
  margin-top: 0;
}

.customer-app-page .triptalk-booking-box h2 {
  color: #fff;
}

.customer-app-page .triptalk-booking-box .eyebrow,
.customer-app-page .triptalk-booking-box p {
  color: #d9eeee;
}

.coupon-detail-list,
.coupon-wallet-list,
.partner-coupon-list {
  display: grid;
  gap: 12px;
}

.coupon-offer-card,
.coupon-wallet-card,
.coupon-verify-card {
  border: 1px solid rgba(12, 44, 54, 0.12);
  border-radius: 8px;
  padding: 16px;
  background: #fff;
}

.coupon-offer-card span,
.coupon-wallet-card > span {
  display: inline-flex;
  width: fit-content;
  border-radius: 999px;
  padding: 4px 9px;
  background: #fff7d6;
  color: #6a3f00;
  font-size: 12px;
  font-weight: 800;
}

.coupon-offer-card h2,
.coupon-wallet-card h2 {
  margin: 10px 0 6px;
}

body.explore-mobile-detail-page .coupon-detail-section .accordion-body {
  padding: 0 14px 14px;
}

body.explore-mobile-detail-page .coupon-detail-list {
  gap: 8px;
}

body.explore-mobile-detail-page .coupon-offer-card {
  display: grid;
  gap: 10px;
  padding: 14px;
  border-radius: 14px;
}

body.explore-mobile-detail-page .coupon-offer-card h2 {
  margin: 0;
  font-size: 1.08rem;
  font-weight: 950;
  line-height: 1.08;
  white-space: nowrap;
}

body.explore-mobile-detail-page .coupon-qr-button {
  min-height: 46px;
  border-radius: 999px;
  font-size: 1.08rem;
  font-weight: 950;
}

.coupon-qr-image {
  width: 156px;
  height: 156px;
  border: 1px solid rgba(12, 44, 54, 0.12);
  border-radius: 8px;
  padding: 8px;
  background: #fff;
}

.coupon-qr-preview {
  display: grid;
  min-height: 132px;
  margin: 14px 0;
  place-items: center;
  gap: 6px;
  border: 1px dashed rgba(10, 127, 132, 0.42);
  border-radius: 10px;
  background: linear-gradient(180deg, #f4ffff, #fff);
  color: #0a5961;
  text-align: center;
}

.coupon-qr-preview strong {
  display: grid;
  width: 58px;
  height: 58px;
  place-items: center;
  border-radius: 14px;
  background: #0a7f84;
  color: #fff;
  font-size: 1.2rem;
  font-weight: 950;
}

.coupon-qr-preview img {
  width: 148px;
  height: 148px;
  border-radius: 8px;
  background: #fff;
}

.coupon-qr-preview.has-real-qr {
  border-style: solid;
}

.coupon-qr-button {
  position: relative;
  overflow: hidden;
  width: 100%;
  animation: couponPulse 1.65s ease-in-out infinite;
}

.coupon-qr-button.coupon-attention {
  outline: 3px solid #f4c95d;
  outline-offset: 4px;
  box-shadow: 0 0 0 8px rgba(244, 201, 93, 0.24), 0 18px 34px rgba(10, 127, 132, 0.28);
}

@keyframes couponPulse {
  0%,
  100% {
    box-shadow: 0 10px 24px rgba(10, 127, 132, 0.18);
    transform: translateY(0);
  }
  50% {
    box-shadow: 0 16px 32px rgba(10, 127, 132, 0.3);
    transform: translateY(-1px);
  }
}

/* Mobile detail final overrides */
body.explore-mobile-detail-page .tripbusan-language-switcher {
  position: absolute !important;
  top: 14px !important;
  right: 14px !important;
  left: auto !important;
  z-index: 72 !important;
  margin: 0 !important;
}

body.explore-mobile-detail-page .tripbusan-language-button {
  display: inline-flex !important;
  justify-content: center !important;
  width: 48px !important;
  min-width: 48px !important;
  height: 34px !important;
  min-height: 34px !important;
  padding: 0 !important;
  border-radius: 999px !important;
  font-size: 0.78rem !important;
}

body.explore-mobile-detail-page .tripbusan-language-button span {
  display: none !important;
}

body.explore-mobile-detail-page .tripbusan-language-menu {
  position: absolute !important;
  top: calc(100% + 8px) !important;
  right: 0 !important;
  left: auto !important;
  min-width: 176px !important;
  max-width: min(78vw, 260px) !important;
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 6px !important;
  padding: 8px !important;
}

body.explore-mobile-detail-page .tripbusan-language-menu[hidden] {
  display: none !important;
}

body.explore-mobile-detail-page .customer-simple-header {
  padding-right: 70px !important;
}

body.explore-mobile-detail-page .explore-mobile-hero {
  --hero-photo-size: min(calc(100vw - 28px), 520px);
}

body.explore-mobile-detail-page .hero-photo-nav {
  top: calc(var(--hero-photo-size, min(calc(100vw - 28px), 520px)) / 2) !important;
  transform: translateY(-50%) !important;
  width: 46px !important;
  height: 54px !important;
  font-size: 2.05rem !important;
  background: rgba(8, 48, 54, 0.72) !important;
  pointer-events: auto !important;
}

body.explore-mobile-detail-page .hero-photo-prev {
  left: 10px !important;
}

body.explore-mobile-detail-page .hero-photo-next {
  right: 10px !important;
}

body.explore-mobile-detail-page .place-map-block {
  gap: 10px !important;
}

body.explore-mobile-detail-page .place-travel-metrics {
  display: grid !important;
  width: calc(100% + 24px) !important;
  margin-inline: -12px !important;
  box-sizing: border-box !important;
  gap: 8px !important;
  padding: 12px !important;
  border: 1px solid rgba(10, 127, 132, 0.22) !important;
  border-radius: 18px !important;
  background: #e8fbf8 !important;
  color: #103f46 !important;
  font-size: clamp(0.88rem, 3.65vw, 1rem) !important;
  font-weight: 950 !important;
  line-height: 1.22 !important;
  box-shadow: 0 12px 26px rgba(10, 127, 132, 0.12) !important;
}

body.explore-mobile-detail-page .place-travel-metrics span {
  display: block !important;
  padding: 10px 12px !important;
  border-radius: 13px !important;
  background: rgba(255, 255, 255, 0.78) !important;
  white-space: nowrap !important;
  letter-spacing: 0 !important;
}

.taxi-action-helper {
  display: grid;
  gap: 6px;
  margin: 28px 2px 0;
  color: #315960;
  font-size: 0.94rem;
  font-weight: 850;
  line-height: 1.38;
}

.taxi-action-helper span {
  display: block;
}

body.explore-mobile-detail-page .review-slider {
  cursor: grab !important;
  margin-right: -14px !important;
  padding-right: 14px !important;
  touch-action: pan-y !important;
  overscroll-behavior-inline: contain !important;
  user-select: none !important;
}

body.explore-mobile-detail-page .review-slider.is-dragging {
  cursor: grabbing !important;
  scroll-snap-type: none !important;
}

body.explore-mobile-detail-page .review-slide-card {
  flex-basis: min(72vw, 250px) !important;
}

body.explore-mobile-detail-page .google-review-card {
  min-height: 96px !important;
  max-height: 160px !important;
  padding: 14px !important;
  gap: 6px !important;
}

body.explore-mobile-detail-page .google-review-card span {
  padding: 4px 7px !important;
  font-size: 0.58rem !important;
}

body.explore-mobile-detail-page .google-review-card strong {
  font-size: 0.88rem !important;
  line-height: 1.25 !important;
}

body.explore-mobile-detail-page .google-review-card p {
  display: -webkit-box !important;
  overflow: hidden !important;
  -webkit-box-orient: vertical !important;
  -webkit-line-clamp: 4 !important;
  font-size: 0.78rem !important;
  line-height: 1.35 !important;
}

body.explore-mobile-detail-page .google-review-card small {
  font-size: 0.72rem !important;
}

body.explore-mobile-detail-page .transport-four-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 8px !important;
}

body.explore-mobile-detail-page .transport-icon-tile {
  display: grid !important;
  min-height: 88px !important;
  padding: 12px 8px !important;
  place-items: center !important;
  align-content: center !important;
  gap: 10px !important;
  border-radius: 14px !important;
  font-size: 0.78rem !important;
  line-height: 1.1 !important;
}

body.explore-mobile-detail-page .transport-icon-tile span {
  display: grid;
  width: 30px;
  height: 30px;
  place-items: center;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.86);
  color: #0b5960;
  font-size: 1.05rem;
  font-weight: 950;
}

body.explore-mobile-detail-page .transport-icon-tile strong {
  display: block;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

body.explore-mobile-detail-page .taxi-action-helper {
  margin-top: 30px !important;
  padding: 2px 2px 0 !important;
  gap: 8px !important;
  font-size: 0.9rem !important;
  line-height: 1.5 !important;
}

body.explore-mobile-detail-page .reservation-menu-row {
  grid-template-columns: 68px minmax(0, 1fr) 126px !important;
  align-items: center !important;
  gap: 10px !important;
  min-height: 86px !important;
  padding: 10px !important;
  overflow: hidden !important;
}

body.explore-mobile-detail-page .reservation-menu-row img,
body.explore-mobile-detail-page .reservation-menu-row .compact-menu-photo-placeholder {
  width: 68px !important;
  height: 68px !important;
  border-radius: 12px !important;
}

body.explore-mobile-detail-page .reservation-menu-info {
  min-width: 0 !important;
  overflow: hidden !important;
}

body.explore-mobile-detail-page .reservation-menu-info strong,
body.explore-mobile-detail-page .reservation-menu-info span {
  display: block !important;
  min-width: 0 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

body.explore-mobile-detail-page .reservation-menu-row .compact-menu-order {
  justify-content: end !important;
  grid-template-columns: 38px 40px 38px !important;
  gap: 5px !important;
}

body.explore-mobile-detail-page .reservation-menu-row [data-menu-quantity] {
  width: 40px !important;
  min-height: 46px !important;
  height: 46px !important;
  padding: 4px !important;
  border-radius: 12px !important;
  font-size: 1rem !important;
  font-weight: 900 !important;
}

body.explore-mobile-detail-page .reservation-menu-row .menu-count-button,
body.explore-mobile-detail-page .reservation-menu-row .menu-add-button {
  width: 38px !important;
  height: 46px !important;
  border-radius: 12px !important;
  font-size: 1.35rem !important;
}

body.explore-mobile-detail-page .compact-menu-quantity {
  font-size: 0 !important;
}

body.explore-mobile-detail-page .compact-explore-reservation-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 10px !important;
}

body.explore-mobile-detail-page .compact-explore-reservation-grid .reservation-time-field {
  grid-column: 1 / -1 !important;
}

body.explore-mobile-detail-page .reservation-time-chips {
  display: flex !important;
  gap: 8px !important;
  overflow-x: auto !important;
  padding: 6px 0 2px !important;
  scrollbar-width: none !important;
}

body.explore-mobile-detail-page .reservation-time-chips::-webkit-scrollbar {
  display: none !important;
}

body.explore-mobile-detail-page .reservation-time-chips button {
  flex: 0 0 auto !important;
  min-width: 76px !important;
  min-height: 44px !important;
  border-radius: 999px !important;
  font-size: 1rem !important;
  font-weight: 950 !important;
}

body.explore-mobile-detail-page .reservation-time-empty {
  display: block !important;
  width: 100% !important;
  padding: 12px !important;
  border-radius: 14px !important;
  background: #fff4e8 !important;
  color: #a34415 !important;
  font-weight: 900 !important;
}

body.explore-mobile-detail-page .reservation-menu-summary-view {
  display: grid !important;
  gap: 6px !important;
  margin-top: 8px !important;
  padding: 10px 12px !important;
  border: 1px solid rgba(10, 127, 132, 0.16) !important;
  border-radius: 14px !important;
  background: #f3fbfa !important;
}

body.explore-mobile-detail-page .reservation-menu-summary-view[hidden] {
  display: none !important;
}

body.explore-mobile-detail-page .reservation-menu-summary-view strong {
  color: #687f85 !important;
  font-size: 0.78rem !important;
  font-weight: 900 !important;
}

body.explore-mobile-detail-page .reservation-menu-summary-view span {
  display: block !important;
  min-width: 0 !important;
  overflow: hidden !important;
  color: #0b3338 !important;
  font-size: 0.95rem !important;
  font-weight: 950 !important;
  line-height: 1.25 !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

body.explore-mobile-detail-page #reservation-nationality,
body.explore-mobile-detail-page #stay-nationality,
body.explore-mobile-detail-page #reservation-sns {
  display: none !important;
}

@media (max-width: 430px) {
  body.explore-mobile-detail-page .reservation-confirmation-page {
    width: 100% !important;
    margin: 12px auto !important;
    border-radius: 18px !important;
  }

  body.explore-mobile-detail-page .reservation-summary-card,
  body.explore-mobile-detail-page .reservation-code-card,
  body.explore-mobile-detail-page .inline-reservation-chat,
  body.explore-mobile-detail-page .post-complete-picks {
    margin: 0 10px !important;
    padding: 14px !important;
    border-radius: 16px !important;
  }
}

@media (max-width: 480px) {
  body.voucher-body {
    background: #f5fbfa !important;
  }

  .voucher-main.voucher-soitaxi {
    width: 100% !important;
    max-width: 430px !important;
    margin: 0 auto !important;
    padding: 8px 10px 22px !important;
  }

  .voucher-soitaxi .voucher-top-card,
  .voucher-soitaxi .voucher-info-card,
  .voucher-soitaxi .voucher-driver-card {
    padding: 14px !important;
    border-radius: 16px !important;
  }

  .voucher-key-list div,
  .voucher-driver-list div {
    grid-template-columns: 78px minmax(0, 1fr) !important;
    gap: 8px !important;
  }

  .voucher-info-actions,
  .voucher-soitaxi .voucher-visible-actions,
  .voucher-soitaxi .voucher-quick-phrases {
    grid-template-columns: 1fr !important;
  }

  .voucher-chat-form {
    grid-template-columns: 1fr !important;
  }
}

.booking-wallet-tabs {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  margin: 12px 0;
}

.booking-wallet-tabs button {
  border: 1px solid rgba(12, 44, 54, 0.12);
  background: #fff;
  border-radius: 999px;
  padding: 9px 12px;
  white-space: nowrap;
  font-weight: 800;
}

.booking-wallet-tabs button.active {
  background: #113d46;
  color: #fff;
}

.coupon-verify-list {
  display: grid;
  gap: 10px;
  margin: 16px 0;
}

.coupon-verify-list div {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: 10px;
}

.coupon-verify-list dt {
  color: #63737a;
  font-weight: 800;
}

.coupon-verify-card.available {
  border-color: #1c9b73;
}

.coupon-verify-card.used,
.coupon-verify-card.expired {
  border-color: #d36b4a;
}

.coupon-home-card em {
  display: block;
  color: #fff;
  font-style: normal;
  font-weight: 800;
  margin-top: 4px;
}

.partner-coupon-form .wide {
  grid-column: 1 / -1;
}

.partner-quick-actions {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin: 16px 0;
}

.partner-action-card,
.partner-upload-button {
  border: 1px solid rgba(15, 23, 42, 0.12);
  background: #fff;
  border-radius: 8px;
  padding: 14px;
  text-align: left;
  color: #0f172a;
  box-shadow: 0 8px 22px rgba(15, 23, 42, 0.06);
}

.partner-action-card strong,
.partner-action-card span {
  display: block;
}

.partner-action-card strong {
  margin-bottom: 6px;
  font-size: 1rem;
}

.partner-action-card span {
  color: #64748b;
  line-height: 1.45;
}

.partner-upload-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-weight: 800;
  margin-bottom: 10px;
}

.partner-upload-button input {
  display: none;
}

.partner-qr-preview {
  width: 180px;
  height: 180px;
  padding: 8px;
  border-radius: 8px;
  background: #fff;
  border: 1px solid rgba(15, 23, 42, 0.12);
}

.partner-link-focus-card {
  border-color: rgba(16, 185, 129, 0.35);
  background: linear-gradient(180deg, rgba(236, 253, 245, 0.9), #fff);
}

.partner-link-copy-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px;
  margin: 12px 0;
  border: 1px solid rgba(15, 23, 42, 0.12);
  border-radius: 8px;
  background: #fff;
}

.partner-link-copy-card strong {
  min-width: 0;
  overflow-wrap: anywhere;
  font-size: 0.95rem;
}

.partner-promo-card .partner-link-copy-card,
.partner-link-focus-card .partner-link-copy-card {
  border-color: rgba(8, 123, 126, 0.26);
  background: linear-gradient(135deg, #f0fffb, #ffffff);
}

.partner-marketing-callout {
  display: grid;
  gap: 5px;
  margin: 14px 0;
  padding: 14px;
  border: 1px solid rgba(8, 123, 126, 0.18);
  border-radius: 14px;
  background: linear-gradient(135deg, #fff8df, #effefa);
  color: #123942;
}

.partner-marketing-callout strong {
  font-size: 1rem;
  font-weight: 950;
}

.partner-marketing-callout span {
  color: #526a72;
  font-weight: 800;
  line-height: 1.45;
}

.partner-dashboard-main {
  color: #17212b;
}

.partner-dashboard-main .inquiry-intro {
  max-width: 760px;
}

.partner-dashboard-main .inquiry-intro h1 {
  letter-spacing: 0;
}

.partner-dashboard-main .chat-language-note {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  border-color: rgba(15, 23, 42, 0.1);
  border-radius: 8px;
  background: #ffffff;
  box-shadow: 0 12px 34px rgba(15, 23, 42, 0.06);
}

.partner-dashboard-main .chat-language-note h2 {
  margin: 3px 0 5px;
  color: #111827;
  font-size: clamp(1.35rem, 3vw, 2rem);
  letter-spacing: 0;
}

.partner-dashboard-main .chat-language-note p {
  margin: 0;
  color: #64748b;
}

body.partner-authenticated .partner-dashboard-main .inquiry-intro,
body.partner-authenticated .partner-dashboard-main .compact-booking-card {
  display: none;
}

.partner-overview-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.partner-overview-strip.compact {
  margin-bottom: 4px;
}

.partner-overview-strip .metric-xl-card {
  min-height: 94px;
  padding: 15px;
  border-color: rgba(15, 23, 42, 0.1);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 10px 28px rgba(15, 23, 42, 0.06);
}

.partner-overview-strip .metric-xl-card strong {
  color: #0f172a;
  font-size: clamp(1.45rem, 4vw, 2.2rem);
  letter-spacing: 0;
}

.partner-overview-strip .metric-xl-card p {
  color: #64748b;
  font-size: 0.8rem;
}

.partner-status-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 16px;
  align-items: center;
  padding: 20px;
  border: 1px solid rgba(15, 23, 42, 0.1);
  border-radius: 8px;
  background: linear-gradient(135deg, #f8fafc, #ffffff);
  box-shadow: 0 14px 34px rgba(15, 23, 42, 0.06);
}

.partner-status-hero h2 {
  margin: 4px 0 7px;
  color: #0f172a;
  font-size: clamp(1.35rem, 4vw, 2rem);
  letter-spacing: 0;
}

.partner-status-hero p {
  margin: 0;
  color: #64748b;
  line-height: 1.55;
}

.partner-status-score {
  min-width: 118px;
  padding: 14px;
  border: 1px solid rgba(20, 184, 166, 0.22);
  border-radius: 8px;
  background: #ecfeff;
  text-align: center;
}

.partner-status-score strong,
.partner-status-score span {
  display: block;
}

.partner-status-score strong {
  color: #0f766e;
  font-size: 1.8rem;
}

.partner-status-score span {
  color: #475569;
  font-size: 0.78rem;
  font-weight: 800;
}

.partner-business-card {
  border-radius: 8px;
  box-shadow: 0 10px 28px rgba(15, 23, 42, 0.05);
}

#partner-quick-panel {
  margin: 16px 0 18px;
  padding: 22px;
  border: 1px solid rgba(15, 118, 110, 0.16);
  border-radius: 16px;
  background: linear-gradient(135deg, rgba(236, 254, 255, 0.96), rgba(255, 255, 255, 0.98));
  box-shadow: 0 18px 42px rgba(15, 23, 42, 0.08);
}

#partner-quick-panel h2 {
  margin: 4px 0 8px;
  color: #0f172a;
  font-size: clamp(1.55rem, 4vw, 2.3rem);
  letter-spacing: -0.03em;
}

#partner-quick-panel p {
  margin: 0;
  color: #475569;
  line-height: 1.55;
}

.partner-editor-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 10px;
}

.partner-editor-grid .wide {
  grid-column: 1 / -1;
}

.partner-menu-editor {
  display: grid;
  gap: 12px;
}

.partner-menu-editor-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.partner-menu-editor-head strong {
  color: #0f172a;
  font-size: 1rem;
}

.partner-menu-editor-list {
  display: grid;
  gap: 10px;
}

.partner-menu-editor-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  padding: 14px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 12px;
  background: #f8fafc;
}

.partner-menu-photo-box {
  display: grid;
  gap: 8px;
  grid-row: span 3;
}

.partner-menu-photo-box img,
.partner-menu-photo-box span {
  display: grid;
  width: 100%;
  aspect-ratio: 1 / 1;
  place-items: center;
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 12px;
  background: #eef6f5;
  color: #557075;
  object-fit: cover;
  font-size: 0.82rem;
  font-weight: 900;
}

.partner-menu-photo-box input[type="file"] {
  font-size: 0.82rem;
}

.partner-menu-editor-row input,
.partner-menu-editor-row textarea {
  width: 100%;
}

.partner-editor-grid input,
.partner-editor-grid select,
.partner-editor-grid textarea,
.partner-coupon-form input,
.partner-coupon-form select,
.owner-hours-grid input[type="time"] {
  width: 100%;
  box-sizing: border-box;
}

.partner-menu-editor-row textarea {
  grid-column: 1 / -1;
  min-height: 88px;
}

.partner-menu-visible-toggle {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  grid-column: 1 / span 1;
  color: #334155;
  font-size: 0.92rem;
  font-weight: 700;
}

.partner-business-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.partner-business-stats span {
  padding: 9px 10px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 8px;
  color: #334155;
  background: #f8fafc;
  font-size: 0.82rem;
  font-weight: 850;
  text-align: center;
}

.partner-coupon-form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 4px;
}

.partner-coupon-form .wide {
  grid-column: 1 / -1;
}

.partner-coupon-form select {
  width: 100%;
  min-height: 46px;
  border: 1px solid #cbd8dd;
  border-radius: 10px;
  padding: 0 12px;
  color: #102f3a;
  background: #fff;
  font: inherit;
}

.owner-simple-form,
.owner-hours-grid {
  padding: 12px;
  border: 1px solid rgba(10, 127, 132, 0.14);
  border-radius: 12px;
  background: #f4fbfa;
}

.owner-hours-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin: 12px 0;
}

.owner-hours-grid input[type="time"],
.owner-simple-form input,
.owner-simple-form select {
  min-height: 52px;
  font-size: 1rem;
  font-weight: 850;
}

.owner-hours-check {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 48px;
  padding: 10px 12px;
  border-radius: 10px;
  background: #fff;
}

.owner-closed-days,
.partner-youtube-grid {
  display: grid;
  grid-column: 1 / -1;
  gap: 10px;
}

.owner-closed-days strong,
.partner-youtube-grid strong {
  color: #12333d;
  font-size: 0.92rem;
}

.owner-closed-day-list {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 6px;
}

.owner-closed-day-list label {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  min-height: 42px;
  border: 1px solid rgba(10, 127, 132, 0.14);
  border-radius: 8px;
  background: #fff;
  font-size: 0.86rem;
  font-weight: 850;
}

.partner-youtube-grid input {
  width: 100%;
  min-height: 52px;
  box-sizing: border-box;
}

.partner-phone-copy-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
}

.partner-phone-copy-row .secondary-button-like {
  min-height: 52px;
  padding-inline: 12px;
  white-space: nowrap;
}

.owner-marketing-status {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(118px, 0.34fr);
  gap: 12px;
  align-items: stretch;
  margin: 12px 0;
  padding: 14px;
  border: 1px solid rgba(14, 116, 144, 0.18);
  border-radius: 10px;
  background: #f8fcff;
}

.owner-marketing-status.ready {
  border-color: rgba(16, 185, 129, 0.28);
  background: #f3fff8;
}

.owner-marketing-status span {
  color: #0d7377;
  font-size: 0.75rem;
  font-weight: 950;
  letter-spacing: 0.08em;
}

.owner-marketing-status h3 {
  margin: 5px 0 7px;
  color: #12333d;
  font-size: 1.16rem;
  line-height: 1.2;
  letter-spacing: 0;
}

.owner-marketing-status p {
  margin: 0;
  color: #526a72;
  line-height: 1.5;
}

.owner-marketing-status aside {
  display: grid;
  align-content: center;
  gap: 5px;
  padding: 12px;
  border-radius: 8px;
  background: #fff;
}

.owner-marketing-status aside strong {
  color: #0f766e;
  font-size: 1.15rem;
}

.owner-marketing-status aside small {
  color: #64748b;
  line-height: 1.35;
}

.owner-marketing-items {
  display: grid;
  gap: 8px;
  margin-top: 12px;
}

.owner-marketing-items > strong {
  color: #12333d;
  font-size: 0.92rem;
}

.owner-marketing-items article {
  display: grid;
  gap: 4px;
  padding: 10px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 8px;
  background: #fff;
}

.owner-marketing-items article span {
  color: #0d7478;
  font-size: 0.74rem;
  font-weight: 950;
}

.owner-marketing-items article h4 {
  margin: 0;
  color: #0f172a;
  font-size: 0.96rem;
  line-height: 1.25;
  letter-spacing: 0;
}

.owner-marketing-items article p {
  color: #526a72;
  font-size: 0.86rem;
}

.owner-marketing-upload {
  display: grid;
  gap: 8px;
  margin-top: 12px;
  padding: 12px;
  border: 1px dashed rgba(13, 115, 119, 0.32);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.72);
}

.owner-marketing-upload label {
  display: grid;
  gap: 8px;
  color: #12333d;
  font-weight: 950;
}

.owner-marketing-upload input[type="file"] {
  width: 100%;
  min-height: 48px;
  padding: 10px;
  border: 1px solid rgba(13, 115, 119, 0.2);
  border-radius: 10px;
  background: #fff;
}

.owner-marketing-upload .submit-cta {
  width: 100%;
  margin: 0;
}

.owner-marketing-flow {
  display: grid;
  gap: 6px;
  margin-top: 12px;
  padding: 12px;
  border: 1px solid rgba(13, 115, 119, 0.18);
  border-radius: 10px;
  background: #fff;
}

.owner-marketing-flow > span {
  width: fit-content;
  padding: 4px 8px;
  border-radius: 999px;
  color: #0c555b;
  background: #e8fbf6;
  font-size: 0.76rem;
  font-weight: 950;
}

.owner-marketing-flow.writing > span {
  color: #7c4a03;
  background: #fff2cc;
}

.owner-marketing-flow.ready > span {
  color: #075e3c;
  background: #dff8e8;
}

.owner-marketing-flow strong {
  color: #12333d;
  line-height: 1.35;
}

.owner-marketing-flow .submit-cta {
  width: 100%;
  margin-top: 4px;
}

.partner-results-main {
  padding-top: 18px;
}

.partner-results-card {
  width: min(720px, calc(100% - 24px));
  margin: 0 auto;
}

.partner-results-card h1 {
  margin: 6px 0 8px;
  color: #082f39;
  letter-spacing: 0;
}

.partner-results-list {
  display: grid;
  gap: 10px;
  margin: 16px 0;
}

.partner-result-row {
  display: grid;
  gap: 7px;
  padding: 12px;
  border: 1px solid rgba(13, 115, 119, 0.16);
  border-radius: 10px;
  background: #f8fcff;
}

.partner-result-row span {
  color: #0d7377;
  font-size: 0.78rem;
  font-weight: 950;
}

.partner-result-row strong {
  color: #12333d;
  line-height: 1.3;
}

.partner-result-row p {
  margin: 0;
  color: #526a72;
  font-size: 0.9rem;
  line-height: 1.45;
}

.partner-result-row .submit-cta,
.partner-result-row .secondary-button-like {
  width: 100%;
}

.partner-upload-overlay {
  position: fixed;
  left: 12px;
  right: 12px;
  bottom: calc(72px + env(safe-area-inset-bottom, 0px));
  z-index: 9999;
  display: grid;
  gap: 4px;
  padding: 13px 14px;
  border: 1px solid rgba(8, 123, 126, 0.24);
  border-radius: 12px;
  background: #083039;
  color: #fff;
  box-shadow: 0 16px 36px rgba(8, 47, 57, 0.28);
}

.partner-upload-overlay[hidden] {
  display: none;
}

.partner-upload-overlay strong {
  font-size: 0.95rem;
}

.partner-upload-overlay span {
  color: rgba(255, 255, 255, 0.82);
  font-size: 0.86rem;
  line-height: 1.35;
}

body.partner-uploading [data-upload-place] {
  opacity: 0.72;
  pointer-events: none;
}

body.compact-chat-page .inquiry-card {
  padding: 8px 10px calc(8px + env(safe-area-inset-bottom)) !important;
  border-width: 1px 0 0 !important;
  border-radius: 18px 18px 0 0 !important;
  background: #f7f7f7 !important;
  box-shadow: 0 -2px 12px rgba(0, 0, 0, 0.08) !important;
}

body.compact-chat-page #chat-form {
  width: 100%;
  margin: 0;
}

.selected-photo-preview {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin: 8px 0 10px;
}

.selected-photo-preview figure {
  position: relative;
  overflow: hidden;
  margin: 0;
  aspect-ratio: 1;
  border-radius: 8px;
  background: #e6f4f1;
}

.selected-photo-preview img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.selected-photo-preview figcaption,
.selected-photo-more {
  position: absolute;
  top: 5px;
  left: 5px;
  display: inline-flex;
  min-width: 22px;
  height: 22px;
  align-items: center;
  justify-content: center;
  padding: 0 6px;
  border-radius: 999px;
  color: #fff;
  background: rgba(8, 47, 57, 0.78);
  font-size: 0.72rem;
  font-weight: 950;
}

.selected-photo-more {
  position: relative;
  top: auto;
  left: auto;
  min-height: 44px;
  height: auto;
}

.owner-coupon-card > .primary-cta,
.owner-hours-card .primary-cta {
  margin-top: 10px;
}

.partner-coupon-list {
  display: grid;
  gap: 8px;
  margin-top: 12px;
}

.partner-coupon-row {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding: 12px;
  border: 1px solid rgba(15, 23, 42, 0.1);
  border-radius: 8px;
  background: #f8fafc;
}

.partner-coupon-row strong,
.partner-coupon-row span,
.partner-coupon-row small {
  display: block;
}

.partner-coupon-row strong {
  color: #0f172a;
}

.partner-coupon-row span,
.partner-coupon-row small {
  color: #64748b;
  line-height: 1.45;
}

@media (max-width: 760px) {
  .partner-dashboard-main {
    width: min(100% - 24px, 1180px);
    padding-top: 20px;
  }

  .partner-panel {
    gap: 14px;
  }

  .partner-dashboard-main .inquiry-intro {
    padding: 2px 0 4px;
  }

  .partner-dashboard-main .inquiry-intro h1 {
    font-size: 2rem;
    line-height: 1.1;
  }

  .partner-dashboard-main .compact-booking-card {
    padding: 16px;
    border-radius: 8px;
  }

  .partner-dashboard-main .chat-language-note {
    align-items: stretch;
    flex-direction: column;
    padding: 16px;
  }

  .partner-dashboard-main .chat-language-note .secondary-button-like {
    width: 100%;
  }

  .partner-overview-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
  }

  .partner-overview-strip .metric-xl-card {
    min-height: 84px;
    padding: 12px;
  }

  .partner-status-hero {
    grid-template-columns: 1fr;
    padding: 16px;
  }

  .partner-status-score {
    display: flex;
    justify-content: space-between;
    min-width: 0;
    text-align: left;
  }

  #partner-quick-panel {
    margin-top: 12px;
    padding: 18px;
  }

  .partner-editor-grid {
    grid-template-columns: 1fr;
  }

  .partner-menu-editor-row {
    grid-template-columns: 1fr;
    gap: 12px;
    padding: 12px;
  }

  .partner-menu-editor-row input,
  .partner-menu-editor-row textarea,
  .partner-editor-grid input,
  .partner-editor-grid select,
  .partner-editor-grid textarea,
  .partner-coupon-form input,
  .partner-coupon-form select,
  .owner-hours-grid input[type="time"] {
    min-height: 52px;
    font-size: 1rem;
  }

  .partner-menu-editor-row textarea,
  .partner-editor-grid textarea {
    min-height: 96px;
  }

  .partner-quick-actions {
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .partner-tabs {
    position: sticky;
    top: 58px;
    z-index: 20;
    overflow-x: auto;
    margin: 0 -12px 10px;
    padding: 10px 12px;
    background: rgba(248, 250, 252, 0.94);
    backdrop-filter: blur(10px);
  }

  .partner-tabs button {
    white-space: nowrap;
    min-height: 44px;
    border-radius: 8px;
  }

  .partner-tabs {
    scrollbar-width: none;
  }

  .partner-tabs::-webkit-scrollbar {
    display: none;
  }

  .partner-action-card,
  .partner-upload-button {
    width: 100%;
    min-height: 58px;
    padding: 13px;
  }

  .partner-panel .button-row,
  .partner-content-card .button-row {
    display: grid;
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .partner-panel .button-row > *,
  .partner-content-card .button-row > *,
  .partner-panel .primary-cta,
  .partner-panel .secondary-button-like {
    width: 100%;
  }

  .partner-link-copy-card {
    align-items: stretch;
    flex-direction: column;
  }

  .partner-business-stats,
  .partner-coupon-form {
    grid-template-columns: 1fr;
  }

  .partner-coupon-form .wide {
    grid-column: auto;
  }

  .partner-coupon-row {
    flex-direction: column;
  }

  .partner-photo-preview-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .partner-menu-editor-head {
    align-items: flex-start;
    flex-direction: column;
  }

  .partner-menu-visible-toggle {
    grid-column: auto;
  }

  .owner-closed-day-list {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .partner-phone-copy-row,
  .owner-marketing-status {
    grid-template-columns: 1fr;
  }

  .partner-phone-copy-row .secondary-button-like {
    width: 100%;
  }
}

/* TripBusan compact chat final layout lock */
body.compact-chat-page {
  padding-bottom: calc(124px + env(safe-area-inset-bottom)) !important;
}

body.compact-chat-page .triptalk-main {
  padding-bottom: calc(124px + env(safe-area-inset-bottom)) !important;
}

body.compact-chat-page .explore-hero {
  padding: calc(4px + env(safe-area-inset-top)) 10px 4px !important;
}

body.compact-chat-page #chat-summary {
  gap: 3px !important;
  padding: 7px 10px !important;
  border-radius: 12px !important;
  font-size: 0.74rem !important;
  line-height: 1.22 !important;
}

body.compact-chat-page #chat-summary span {
  grid-template-columns: 34px minmax(0, 1fr) !important;
  gap: 6px !important;
}

body.compact-chat-page #chat-summary strong,
body.compact-chat-page #chat-summary em {
  line-height: 1.24 !important;
}

body.compact-chat-page .chat-message-list {
  padding: 8px 10px 118px !important;
  gap: 7px !important;
}

body.compact-chat-page .chat-message-card.sender-customer,
body.compact-chat-page .chat-message-card.sender-owner,
body.compact-chat-page .chat-message-card.sender-admin {
  align-self: flex-start !important;
  background: #ffffff !important;
  color: #111111 !important;
  border: 0 !important;
  border-bottom-left-radius: 6px !important;
  border-bottom-right-radius: 16px !important;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.08) !important;
}

body.compact-chat-page .chat-message-card.is-own-message {
  align-self: flex-end !important;
  background: #06c755 !important;
  color: #ffffff !important;
  border: 0 !important;
  border-bottom-left-radius: 16px !important;
  border-bottom-right-radius: 6px !important;
}

body.compact-chat-page .chat-message-card.has-image-message {
  max-width: min(74%, 300px) !important;
  padding: 0 !important;
  overflow: hidden !important;
  background: transparent !important;
  color: #111111 !important;
  box-shadow: none !important;
}

body.compact-chat-page .chat-message-card.has-image-message.is-own-message {
  background: transparent !important;
  color: #111111 !important;
}

body.compact-chat-page .chat-message-card.has-image-message .chat-image-preview {
  display: block !important;
  width: 100% !important;
  max-height: 320px !important;
  object-fit: cover !important;
  border: 0 !important;
  border-radius: 14px !important;
  box-shadow: none !important;
}

body.compact-chat-page .chat-message-card.has-image-message p,
body.compact-chat-page .chat-message-card.has-image-message .chat-original-text {
  display: none !important;
}

body.compact-chat-page .inquiry-card {
  padding: 8px 10px calc(8px + env(safe-area-inset-bottom)) !important;
}

/* TripBusan compact chat hard lock 2026-06-19 */
body.compact-chat-page {
  padding-bottom: calc(176px + env(safe-area-inset-bottom)) !important;
  overflow-x: hidden !important;
}

body.compact-chat-page .triptalk-main {
  padding-bottom: calc(176px + env(safe-area-inset-bottom)) !important;
}

body.compact-chat-page .explore-hero {
  padding: calc(2px + env(safe-area-inset-top)) 8px 2px !important;
}

body.compact-chat-page #chat-summary {
  gap: 2px !important;
  padding: 6px 9px !important;
  margin: 0 !important;
  border-radius: 10px !important;
  box-shadow: none !important;
  font-size: 0.72rem !important;
  line-height: 1.18 !important;
}

body.compact-chat-page #chat-summary span {
  grid-template-columns: 32px minmax(0, 1fr) !important;
  gap: 5px !important;
  padding: 0 !important;
  margin: 0 !important;
  min-height: 0 !important;
}

body.compact-chat-page .chat-message-list {
  display: grid !important;
  grid-auto-rows: max-content !important;
  align-content: start !important;
  padding: 6px 10px calc(168px + env(safe-area-inset-bottom)) !important;
  gap: 7px !important;
  min-height: calc(100dvh - 210px) !important;
  max-height: none !important;
  overflow: visible !important;
}

body.compact-chat-page .chat-message-card {
  width: fit-content !important;
  max-width: min(76%, 320px) !important;
  margin: 0 !important;
  padding: 8px 11px !important;
  border: 0 !important;
  box-sizing: border-box !important;
}

body.compact-chat-page .chat-message-card.sender-customer,
body.compact-chat-page .chat-message-card.sender-owner,
body.compact-chat-page .chat-message-card.sender-admin,
body.compact-chat-page .chat-message-card.sender-system {
  justify-self: start !important;
  align-self: auto !important;
  background: #ffffff !important;
  color: #111111 !important;
  border-bottom-left-radius: 5px !important;
  border-bottom-right-radius: 16px !important;
}

body.compact-chat-page .chat-message-card.is-own-message {
  justify-self: end !important;
  align-self: auto !important;
  background: #06c755 !important;
  color: #ffffff !important;
  border-bottom-left-radius: 16px !important;
  border-bottom-right-radius: 5px !important;
}

body.compact-chat-page .chat-message-card p,
body.compact-chat-page .chat-message-card small,
body.compact-chat-page .chat-message-card span {
  color: inherit !important;
}

body.compact-chat-page .chat-message-card p {
  margin: 0 !important;
  font-size: 1rem !important;
  font-weight: 800 !important;
  line-height: 1.35 !important;
}

body.compact-chat-page .chat-original-text {
  margin-top: 4px !important;
  font-size: 0.78rem !important;
  opacity: 0.68 !important;
}

body.compact-chat-page .chat-message-card.has-image-message,
body.compact-chat-page .chat-message-card.has-image-message.is-own-message {
  justify-self: end !important;
  width: min(74vw, 300px) !important;
  max-width: min(74vw, 300px) !important;
  padding: 0 !important;
  background: transparent !important;
  color: #111111 !important;
  box-shadow: none !important;
  border: 0 !important;
  overflow: visible !important;
}

body.compact-chat-page .chat-message-card.has-image-message:not(.is-own-message) {
  justify-self: start !important;
}

body.compact-chat-page .chat-message-card.has-image-message .chat-image-preview {
  width: 100% !important;
  max-height: 315px !important;
  object-fit: cover !important;
  border: 0 !important;
  outline: 0 !important;
  border-radius: 14px !important;
  box-shadow: none !important;
  background: transparent !important;
}

body.compact-chat-page .chat-message-card.has-image-message p,
body.compact-chat-page .chat-message-card.has-image-message .chat-original-text,
body.compact-chat-page .chat-message-card.has-image-message .chat-message-meta {
  display: none !important;
}

body.compact-chat-page .inquiry-card {
  padding: 7px 8px calc(7px + env(safe-area-inset-bottom)) !important;
  min-height: 58px !important;
  background: rgba(255, 255, 255, 0.96) !important;
}

body.compact-chat-page #chat-form {
  grid-template-columns: 30px 30px 30px minmax(0, 1fr) 52px !important;
  gap: 6px !important;
  align-items: center !important;
}

body.compact-chat-page #chat-message {
  height: 42px !important;
  min-height: 42px !important;
  max-height: 84px !important;
  padding: 9px 14px !important;
  border-radius: 999px !important;
  font-size: 1rem !important;
  line-height: 1.25 !important;
}

body.compact-chat-page #chat-form .submit-cta,
body.compact-chat-page .chat-tool-button {
  width: 42px !important;
  min-width: 42px !important;
  height: 42px !important;
  min-height: 42px !important;
  padding: 0 !important;
  border-radius: 999px !important;
}

body.compact-chat-page #chat-form .submit-cta {
  width: 52px !important;
  min-width: 52px !important;
  font-size: 0.9rem !important;
}

body.compact-chat-page .chat-notification-prompt {
  margin: 6px 10px !important;
  padding: 10px 12px !important;
  border-radius: 14px !important;
  box-shadow: 0 8px 22px rgba(7, 91, 94, 0.12) !important;
}
