:root {
  --bg: #f3f0e8;
  --bg-deep: #07131f;
  --surface: rgba(255, 255, 255, 0.92);
  --surface-solid: #ffffff;
  --surface-soft: #f8f6ef;
  --line: rgba(18, 30, 48, 0.1);
  --text: #172133;
  --text-soft: #6c7483;
  --brand: #0c8f79;
  --brand-2: #16c7a1;
  --ink: #0b1726;
  --accent: #f26d3d;
  --gold: #f2bc57;
  --success: #12915f;
  --warning: #bd7b18;
  --danger: #d84e5c;
  --radius: 24px;
  --shadow: 0 18px 46px rgba(16, 25, 40, 0.12);
  --shadow-soft: 0 10px 26px rgba(16, 25, 40, 0.08);
}

/* Customer order center and shared bottom navigation */
.site-bottom-nav {
  position: fixed;
  left: 50%;
  bottom: calc(10px + env(safe-area-inset-bottom));
  z-index: 70;
  width: min(452px, calc(100vw - 24px));
  transform: translateX(-50%);
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 8px;
  padding: 9px;
  border: 1px solid rgba(255, 255, 255, 0.78);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.92);
  box-shadow: 0 18px 44px rgba(10, 28, 40, 0.16);
  backdrop-filter: blur(18px);
}

.site-bottom-nav a {
  display: grid;
  place-items: center;
  gap: 4px;
  min-height: 50px;
  border-radius: 18px;
  color: #657084;
  text-decoration: none;
  font-size: 12px;
  font-weight: 900;
  transition: background 0.18s ease, color 0.18s ease, transform 0.18s ease;
}

.site-bottom-nav a:active {
  transform: scale(0.96);
}

.site-bottom-nav span {
  display: inline-grid;
  place-items: center;
  width: 24px;
  height: 24px;
  border-radius: 999px;
  background: #edf4f3;
  color: #0d8f75;
  font-size: 13px;
}

.site-bottom-nav strong {
  font-size: 12px;
}

body.landing-page .site-bottom-nav [data-nav="home"],
body.playmate-page .site-bottom-nav [data-nav="play"],
body.booking-page .site-bottom-nav [data-nav="play"],
body.star-page .site-bottom-nav [data-nav="star"],
body.lucky-page .site-bottom-nav [data-nav="lucky"],
body.orders-page .site-bottom-nav [data-nav="orders"] {
  color: #073f36;
  background: linear-gradient(135deg, rgba(19, 210, 169, 0.18), rgba(13, 143, 117, 0.1));
}

body.landing-page .site-bottom-nav [data-nav="home"] span,
body.playmate-page .site-bottom-nav [data-nav="play"] span,
body.booking-page .site-bottom-nav [data-nav="play"] span,
body.star-page .site-bottom-nav [data-nav="star"] span,
body.lucky-page .site-bottom-nav [data-nav="lucky"] span,
body.orders-page .site-bottom-nav [data-nav="orders"] span {
  color: #fff;
  background: linear-gradient(135deg, #0d8f75, #19d1a4);
}

.star-shell {
  padding-bottom: 176px;
}

.star-bottom-actions,
.star-pay-footer {
  bottom: calc(84px + env(safe-area-inset-bottom));
}

.mobile-sticky-cta {
  bottom: calc(84px + env(safe-area-inset-bottom));
}

.orders-page {
  min-height: 100vh;
  background:
    radial-gradient(circle at 50% -8%, rgba(24, 205, 165, 0.2), transparent 28%),
    linear-gradient(180deg, #edf8f4 0%, #f8faf9 52%, #eef5f2 100%);
}

.orders-shell {
  width: min(520px, 100%);
  margin: 0 auto;
  padding: 18px 14px 120px;
}

.orders-hero {
  display: grid;
  grid-template-columns: 48px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  padding: 18px;
  border-radius: 28px;
  color: #fff;
  background:
    radial-gradient(circle at 86% 12%, rgba(255, 255, 255, 0.18), transparent 24%),
    linear-gradient(135deg, #061a2d 0%, #0d7d72 100%);
  box-shadow: 0 18px 44px rgba(11, 42, 54, 0.18);
}

.orders-back {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border-radius: 999px;
  color: #102033;
  background: rgba(255, 255, 255, 0.92);
  text-decoration: none;
  font-size: 30px;
  font-weight: 950;
}

.orders-hero span {
  display: inline-flex;
  width: fit-content;
  padding: 6px 12px;
  border-radius: 999px;
  color: #063f35;
  background: #d8ffe7;
  font-size: 12px;
  font-weight: 950;
}

.orders-hero h1 {
  margin: 10px 0 8px;
  font-size: 32px;
  line-height: 1.05;
}

.orders-hero p {
  margin: 0;
  color: rgba(255, 255, 255, 0.82);
  line-height: 1.65;
}

.orders-login-card,
.orders-list-card,
.order-detail-panel {
  margin-top: 14px;
  padding: 18px;
  border: 1px solid rgba(255, 255, 255, 0.8);
  border-radius: 26px;
  background: rgba(255, 255, 255, 0.92);
  box-shadow: 0 12px 34px rgba(16, 25, 40, 0.08);
  backdrop-filter: blur(18px);
}

.orders-login-card h2,
.orders-list-head h2,
.order-detail-head h2 {
  margin: 0;
  color: #121a2b;
}

.orders-login-card p,
.orders-list-head p {
  margin: 8px 0 14px;
  color: #6c7483;
  line-height: 1.65;
}

.orders-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-top: 14px;
}

.orders-summary div {
  padding: 14px 12px;
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.86);
  box-shadow: 0 10px 24px rgba(16, 25, 40, 0.06);
}

.orders-summary span {
  display: block;
  color: #7b8493;
  font-size: 12px;
  font-weight: 900;
}

.orders-summary strong {
  display: block;
  margin-top: 6px;
  color: #0b1726;
  font-size: 26px;
}

.orders-tabs {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin: 14px 0 0;
  padding: 7px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.78);
}

.orders-tabs button {
  min-height: 40px;
  border: 0;
  border-radius: 999px;
  color: #657084;
  background: transparent;
  font-weight: 950;
}

.orders-tabs button.active {
  color: #fff;
  background: linear-gradient(135deg, #0d8f75, #19d1a4);
  box-shadow: 0 10px 22px rgba(16, 181, 144, 0.2);
}

.orders-list-head,
.order-detail-head,
.orders-card-head {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: flex-start;
}

.orders-page-list {
  display: grid;
  gap: 12px;
}

.orders-page-card {
  padding: 16px;
  border: 1px solid rgba(18, 30, 48, 0.08);
  border-radius: 24px;
  background: linear-gradient(180deg, #fff 0%, #f8fbfb 100%);
  box-shadow: 0 8px 22px rgba(16, 25, 40, 0.05);
}

.orders-type {
  display: inline-flex;
  padding: 5px 9px;
  border-radius: 999px;
  color: #0d8f75;
  background: #e8f7f2;
  font-size: 12px;
  font-weight: 950;
}

.orders-page-card h3 {
  margin: 9px 0 5px;
  font-size: 19px;
}

.orders-page-card p {
  margin: 0;
  color: #7b8493;
  font-size: 13px;
}

.orders-card-rows {
  display: grid;
  gap: 8px;
  margin-top: 14px;
}

.orders-card-rows div {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  color: #657084;
}

.orders-card-rows strong {
  color: #172133;
  text-align: right;
}

.orders-card-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 14px;
}

.orders-card-actions .btn {
  min-height: 42px;
  flex: 1 1 120px;
  text-align: center;
  text-decoration: none;
}

.order-detail-panel {
  position: relative;
  overflow: hidden;
}

.order-detail-panel::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 4px;
  background: linear-gradient(90deg, #0d8f75, #19d1a4, #f2bc57);
}

.order-detail-head span {
  display: block;
  margin-bottom: 6px;
  color: #0d8f75;
  font-size: 12px;
  font-weight: 950;
}

.order-detail-close {
  border: 0;
  border-radius: 999px;
  padding: 9px 12px;
  color: #657084;
  background: #eef3f3;
  font-weight: 950;
}

.order-detail-status {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin: 16px 0 8px;
  padding: 12px;
  border-radius: 18px;
  color: #087361;
  background: #e8f7f2;
}

.order-detail-status strong {
  font-size: 13px;
}

.order-detail-rows {
  display: grid;
  gap: 2px;
}

.detail-actions {
  padding-top: 8px;
}

@media (max-width: 640px) {
  .orders-shell {
    padding-inline: 12px;
  }

  .orders-hero {
    border-radius: 26px;
  }

  .orders-hero h1 {
    font-size: 29px;
  }

  .orders-card-head,
  .order-detail-head {
    align-items: flex-start;
  }

  .orders-card-actions .btn {
    flex-basis: 100%;
  }
}

/* Star boost order flow */
body:has(.star-shell) {
  background:
    radial-gradient(circle at 50% -8%, rgba(28, 215, 179, 0.2), transparent 28%),
    linear-gradient(180deg, #eef8f4 0%, #f6f8fb 48%, #eef5f2 100%);
  overflow-x: hidden;
}

.star-shell {
  width: min(480px, 100%);
  max-width: 100vw;
  min-height: 100vh;
  margin: 0 auto;
  padding: 0 14px 104px;
  color: #121a2b;
  position: relative;
  overflow-x: hidden;
}

.star-topbar {
  position: sticky;
  top: 0;
  z-index: 30;
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr) 44px;
  align-items: center;
  height: 56px;
  margin: 0 -14px;
  padding: 0 12px;
  background: rgba(246, 248, 251, 0.88);
  backdrop-filter: blur(18px);
  text-align: center;
  font-weight: 950;
  font-size: 18px;
}

.star-back,
.star-top-service {
  width: 40px;
  height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 0;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.72);
  color: #182034;
  font-weight: 950;
}

.star-back {
  font-size: 32px;
  line-height: 1;
}

.star-top-service {
  font-size: 13px;
}

.floating-service-btn {
  position: fixed;
  top: 76px;
  right: 16px;
  z-index: 75;
  display: grid;
  place-items: center;
  align-content: center;
  width: 70px;
  height: 70px;
  border: 1px solid rgba(255, 255, 255, 0.86);
  border-radius: 25px;
  color: #0d182b;
  background:
    radial-gradient(circle at 72% 18%, rgba(255, 255, 255, 0.92), transparent 24%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.98) 0%, rgba(231, 251, 245, 0.94) 100%);
  box-shadow: 0 16px 38px rgba(11, 30, 45, 0.16), 0 0 0 8px rgba(255, 255, 255, 0.2);
  touch-action: none;
  user-select: none;
  -webkit-user-select: none;
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}

.floating-service-btn::after {
  content: "";
  position: absolute;
  inset: -4px;
  border-radius: 29px;
  border: 1px solid rgba(18, 202, 160, 0.22);
  pointer-events: none;
}

.floating-service-btn.is-dragging {
  transform: scale(1.06);
  box-shadow: 0 24px 48px rgba(11, 30, 45, 0.22), 0 0 0 10px rgba(18, 202, 160, 0.12);
}

.service-orbit {
  position: relative;
  width: 26px;
  height: 18px;
  margin-bottom: 2px;
}

.service-orbit::before,
.service-orbit::after {
  content: "";
  position: absolute;
  border-radius: 999px;
}

.service-orbit::before {
  inset: 0;
  border: 3px solid #13b899;
  border-bottom-color: transparent;
}

.service-orbit::after {
  right: -2px;
  bottom: 0;
  width: 8px;
  height: 8px;
  background: #13b899;
  box-shadow: -22px 0 0 #13b899;
}

.floating-service-btn strong,
.floating-service-btn small {
  display: block;
  line-height: 1;
}

.floating-service-btn strong {
  margin-top: 2px;
  font-size: 16px;
  font-weight: 950;
  letter-spacing: -0.02em;
}

.floating-service-btn small {
  margin-top: 5px;
  color: #7b8798;
  font-size: 10px;
  font-weight: 900;
}

.star-game-banner {
  overflow: hidden;
  position: relative;
  margin: 10px 0 12px;
  min-height: 248px;
  border-radius: 30px;
  padding: 24px;
  color: #fff;
  background:
    radial-gradient(circle at 78% 18%, rgba(255, 225, 135, 0.38), transparent 20%),
    radial-gradient(circle at 28% 104%, rgba(25, 206, 158, 0.42), transparent 38%),
    linear-gradient(135deg, #0a1730 0%, #0e4149 58%, #057a64 100%);
  box-shadow: 0 22px 48px rgba(7, 36, 43, 0.22);
}

.star-game-banner::after {
  content: "";
  position: absolute;
  right: -56px;
  bottom: -84px;
  width: 220px;
  height: 220px;
  border-radius: 50%;
  border: 36px solid rgba(255, 255, 255, 0.08);
}

.star-banner-content {
  position: relative;
  z-index: 1;
  display: flex;
  min-height: 200px;
  flex-direction: column;
  align-items: flex-start;
}

.star-banner-brand {
  display: inline-flex;
  width: fit-content;
  padding: 7px 12px;
  border-radius: 999px;
  color: #112034;
  background: linear-gradient(135deg, #fff6c8 0%, #a8ffe5 100%);
  font-size: 13px;
  font-weight: 950;
}

.star-banner-title {
  display: block;
  margin-top: 32px;
  max-width: 100%;
  text-align: left;
  font-size: clamp(31px, 8.3vw, 44px);
  line-height: 1.08;
  letter-spacing: -0.045em;
  font-weight: 950;
  white-space: nowrap;
  text-shadow: 0 6px 18px rgba(0, 0, 0, 0.28);
}

.star-banner-service-btn {
  display: none;
}

.star-banner-service-btn::before {
  content: "";
  position: absolute;
  inset: -3px;
  border-radius: inherit;
  border: 1px solid rgba(224, 255, 244, 0.62);
  pointer-events: none;
}

.star-banner-service-btn::after {
  display: none;
}

.star-banner-services {
  display: grid;
  grid-template-columns: max-content max-content;
  gap: 4px 20px;
  margin: 17px 0 0;
  max-width: 100%;
  color: rgba(255, 255, 255, 0.78);
  line-height: 1.32;
  font-size: clamp(16px, 4.1vw, 19px);
}

.star-banner-services b,
.star-banner-services em,
.star-banner-services small {
  display: inline-flex;
  align-items: center;
}

.star-banner-services b {
  grid-column: 1 / -1;
  width: 100%;
  margin-right: 0;
  margin-bottom: 1px;
  color: rgba(255, 255, 255, 0.96);
  font-size: clamp(16px, 4.2vw, 18px);
  font-weight: 900;
}

.star-banner-services em {
  margin: 0;
  padding: 0;
  border-radius: 0;
  border: 0;
  background: transparent;
  font-style: normal;
  color: rgba(255, 255, 255, 0.88);
}

.star-banner-services small {
  margin-top: 0;
  color: rgba(255, 255, 255, 0.78);
  font-size: inherit;
  white-space: nowrap;
}

.star-compliance-note {
  margin: 0 0 12px;
  padding: 12px 14px;
  border: 1px solid rgba(18, 30, 48, 0.07);
  border-radius: 18px;
  color: #5f6b7b;
  background: rgba(255, 255, 255, 0.84);
  box-shadow: 0 12px 26px rgba(19, 32, 54, 0.06);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.55;
}

.star-game-row,
.star-form-card,
.star-quote-mini,
.confirm-panel,
.confirm-summary-card {
  border: 1px solid rgba(18, 30, 48, 0.07);
  background: rgba(255, 255, 255, 0.88);
  box-shadow: 0 14px 34px rgba(19, 32, 54, 0.08);
}

.star-game-row {
  width: 100%;
  display: grid;
  grid-template-columns: 42px 72px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  min-height: 66px;
  margin-bottom: 12px;
  border-radius: 22px;
  padding: 12px 15px;
  text-align: left;
}

.star-row-icon,
.game-avatar {
  display: inline-flex;
  width: 42px;
  height: 42px;
  align-items: center;
  justify-content: center;
  border-radius: 15px;
  color: #fff;
  background: linear-gradient(135deg, #19cfa4 0%, #0d7366 100%);
  font-weight: 950;
}

.star-game-row span:not(.star-row-icon) {
  color: #6d7787;
  font-size: 14px;
}

.star-game-row strong {
  min-width: 0;
  color: #121a2b;
  font-size: 16px;
  font-weight: 950;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  text-align: right;
}

.star-form-card {
  overflow: hidden;
  border-radius: 24px;
}

.star-select-row {
  width: 100%;
  min-height: 62px;
  display: grid;
  grid-template-columns: 112px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  border: 0;
  border-bottom: 1px solid rgba(18, 30, 48, 0.07);
  padding: 17px 18px;
  background: transparent;
  text-align: left;
}

.star-select-row:last-child {
  border-bottom: 0;
}

.star-select-row span {
  color: #1a2436;
  font-weight: 900;
}

.star-select-row span em {
  color: #9aa4b3;
  font-style: normal;
  font-size: 12px;
}

.star-select-row.required span::after {
  content: " *";
  color: #ef6b6b;
}

.star-select-row strong {
  min-width: 0;
  max-width: 100%;
  color: #5f6978;
  font-weight: 800;
  text-align: right;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  word-break: break-all;
}

.star-select-row strong::after,
.star-game-row strong::after {
  content: "›";
  margin-left: 8px;
  color: #a6afbc;
}

.star-quote-mini {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-top: 12px;
  border-radius: 24px;
  padding: 12px;
}

.star-quote-mini div {
  padding: 14px;
  border-radius: 18px;
  background: #f7fafc;
}

.star-quote-mini span,
.quote-cards span,
.star-pay-footer span,
.star-pay-footer small {
  display: block;
  color: #7b8493;
  font-size: 13px;
}

.star-quote-mini strong {
  display: block;
  margin-top: 7px;
  color: #0d8f75;
  font-size: 22px;
  font-weight: 950;
}

.star-bottom-actions,
.star-pay-footer {
  position: fixed;
  left: 50%;
  bottom: calc(12px + env(safe-area-inset-bottom));
  z-index: 40;
  width: min(452px, calc(100vw - 24px));
  transform: translateX(-50%);
  display: grid;
  gap: 10px;
  padding: 12px;
  border: 1px solid rgba(255, 255, 255, 0.8);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.94);
  box-shadow: 0 20px 48px rgba(12, 30, 45, 0.18);
  backdrop-filter: blur(18px);
}

.star-bottom-actions {
  grid-template-columns: 0.72fr 1.28fr;
}

.star-reset-btn,
.star-next-btn,
.star-contact-btn {
  min-height: 52px;
  border: 0;
  border-radius: 999px;
  font-weight: 950;
  font-size: 17px;
}

.star-reset-btn {
  color: #425064;
  background: #edf2f5;
}

.star-next-btn {
  color: #fff;
  background: linear-gradient(135deg, #11a98f 0%, #19d1a4 100%);
  box-shadow: 0 14px 26px rgba(16, 181, 144, 0.24);
}

.star-contact-btn {
  color: #0b7e71;
  background: linear-gradient(180deg, #f5fffc 0%, #e9f8f4 100%);
  border: 1px solid rgba(17, 169, 143, 0.26);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.82);
}

.star-next-btn:disabled,
.star-contact-btn:disabled {
  opacity: 0.62;
}

.star-confirm-view {
  padding-bottom: 18px;
}

.confirm-summary-card {
  overflow: hidden;
  position: relative;
  margin: 10px 0 12px;
  border-radius: 28px;
  padding: 22px;
  color: #2f2511;
  background:
    radial-gradient(circle at 88% 10%, rgba(255, 255, 255, 0.54), transparent 18%),
    linear-gradient(135deg, #fff0bf 0%, #f7c66a 48%, #dc9342 100%);
}

.confirm-summary-card::after {
  content: "";
  position: absolute;
  right: -54px;
  bottom: -66px;
  width: 180px;
  height: 180px;
  border-radius: 50%;
  border: 32px solid rgba(255, 255, 255, 0.18);
}

.confirm-tag {
  display: inline-flex;
  padding: 7px 11px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.68);
  font-size: 12px;
  font-weight: 950;
}

.confirm-game-line {
  display: flex;
  gap: 10px;
  align-items: center;
  margin-top: 16px;
  position: relative;
  z-index: 1;
}

.confirm-summary-card h1 {
  position: relative;
  z-index: 1;
  margin: 18px 0 0;
  font-size: 24px;
  line-height: 1.25;
  letter-spacing: -0.03em;
}

.confirm-summary-card p {
  position: relative;
  z-index: 1;
  margin: 10px 0 0;
  color: rgba(47, 37, 17, 0.72);
  line-height: 1.6;
}

.confirm-panel {
  margin-top: 12px;
  border-radius: 24px;
  padding: 18px;
}

.confirm-panel h2 {
  margin: 0 0 14px;
  font-size: 18px;
  font-weight: 950;
}

.quote-cards {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.quote-cards div {
  padding: 16px;
  border-radius: 18px;
  background: #f7fafc;
}

.quote-cards strong {
  display: block;
  margin-top: 8px;
  color: #c65747;
  font-size: 24px;
  font-weight: 950;
}

.star-lead-form label:not(.star-agreement) {
  display: grid;
  grid-template-columns: 92px minmax(0, 1fr);
  gap: 12px;
  align-items: start;
  padding: 13px 0;
  border-bottom: 1px solid rgba(18, 30, 48, 0.07);
}

.star-lead-form label span {
  color: #2b3648;
  font-weight: 900;
}

.plain-input,
.plain-textarea {
  width: 100%;
  border: 0;
  outline: none;
  color: #182034;
  background: transparent;
  text-align: right;
}

.plain-textarea {
  min-height: 76px;
  resize: vertical;
}

.star-agreement {
  display: flex;
  gap: 8px;
  align-items: center;
  margin-top: 14px;
  color: #717b8a;
  font-size: 12px;
  line-height: 1.5;
}

.star-agreement a {
  color: #0a8f78;
  font-weight: 900;
}

.star-pay-footer {
  grid-template-columns: minmax(0, 1fr);
  align-items: stretch;
}

.star-pay-actions {
  display: grid;
  grid-template-columns: 0.92fr 1.08fr;
  gap: 10px;
}

.star-pay-footer strong {
  display: block;
  margin-top: 3px;
  color: #c65747;
  font-size: 22px;
  font-weight: 950;
}

.picker-mask,
.number-mask {
  position: fixed;
  inset: 0;
  z-index: 90;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding: 16px 12px;
  background: rgba(9, 18, 30, 0.42);
}

.picker-sheet,
.number-dialog {
  width: min(480px, 100%);
  max-height: 82vh;
  overflow: hidden;
  border-radius: 28px;
  background: #fff;
  box-shadow: 0 28px 70px rgba(7, 18, 34, 0.25);
}

.picker-sheet {
  position: relative;
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr);
  padding: 20px 16px 16px;
}

.picker-sheet h2,
.number-dialog h2 {
  margin: 0 46px 16px 4px;
  font-size: 20px;
  font-weight: 950;
}

.picker-close {
  position: absolute;
  top: 14px;
  right: 14px;
  width: 36px;
  height: 36px;
  border: 0;
  border-radius: 999px;
  color: #7c8797;
  background: #f2f5f7;
  font-size: 24px;
}

.picker-search {
  margin-bottom: 12px;
}

.picker-search input {
  width: 100%;
  height: 44px;
  border: 1px solid rgba(18, 30, 48, 0.08);
  border-radius: 16px;
  padding: 0 14px;
  outline: none;
  background: #f7fafc;
}

.picker-body {
  min-height: 140px;
  overflow: auto;
  padding: 2px 2px 4px;
}

.sheet-list {
  display: grid;
  gap: 10px;
}

.sheet-option {
  min-height: 68px;
  border: 1px solid rgba(18, 30, 48, 0.08);
  border-radius: 18px;
  padding: 14px;
  background: #fff;
  text-align: left;
}

.sheet-option strong,
.sheet-option span {
  display: block;
}

.sheet-option strong {
  font-weight: 950;
}

.sheet-option span {
  margin-top: 6px;
  color: #7a8493;
  font-size: 13px;
  line-height: 1.5;
}

.sheet-option.is-active,
.sheet-chip.is-active,
.rank-tabs button.is-active,
.rank-option.is-active {
  border-color: rgba(18, 190, 153, 0.72);
  background: linear-gradient(135deg, #eafbf6 0%, #fff 100%);
  box-shadow: 0 0 0 4px rgba(22, 199, 161, 0.12);
}

.sheet-section-title {
  margin: 8px 0 10px;
  color: #7b8493;
  font-size: 13px;
  font-weight: 950;
}

.sheet-chip-grid,
.hero-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.sheet-chip {
  min-height: 46px;
  border: 1px solid rgba(18, 30, 48, 0.08);
  border-radius: 16px;
  background: #fff;
  color: #253047;
  font-weight: 900;
}

.hero-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.rank-picker {
  display: grid;
  grid-template-columns: 84px minmax(0, 1fr);
  gap: 12px;
  min-height: 420px;
}

.rank-tabs {
  display: grid;
  align-content: start;
  gap: 8px;
}

.rank-tabs button {
  min-height: 42px;
  border: 1px solid rgba(18, 30, 48, 0.08);
  border-radius: 14px;
  background: #f7fafc;
  color: #4b5667;
  font-weight: 950;
}

.rank-options {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-content: start;
  gap: 9px;
  overflow: auto;
}

.rank-option {
  min-height: 64px;
  border: 1px solid rgba(18, 30, 48, 0.08);
  border-radius: 16px;
  background: #fff;
  color: #1c283d;
  text-align: left;
  padding: 11px;
}

.rank-option strong,
.rank-option span {
  display: block;
}

.rank-option strong {
  font-size: 13px;
  font-weight: 950;
}

.rank-option span {
  margin-top: 5px;
  color: #7b8493;
  font-size: 13px;
}

.rank-option:disabled {
  opacity: 0.35;
  cursor: not-allowed;
}

.number-mask {
  align-items: center;
}

.number-dialog {
  padding: 22px 18px 18px;
}

.number-dialog input {
  width: 100%;
  height: 52px;
  border: 1px solid rgba(18, 30, 48, 0.12);
  border-radius: 16px;
  padding: 0 14px;
  outline: none;
  font-size: 20px;
  font-weight: 900;
}

.number-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-top: 16px;
}

.number-actions button {
  min-height: 46px;
  border: 0;
  border-radius: 999px;
  font-weight: 950;
}

.number-actions button:first-child {
  background: #edf2f5;
}

.number-actions button:last-child {
  color: #fff;
  background: linear-gradient(135deg, #11a98f 0%, #19d1a4 100%);
}

@media (max-width: 420px) {
  .star-shell {
    padding-left: 10px;
    padding-right: 10px;
  }

  .star-topbar {
    margin-left: -10px;
    margin-right: -10px;
  }

  .star-game-banner {
    min-height: 230px;
    padding: 17px;
    border-radius: 26px;
  }

  .star-banner-title {
    max-width: 100%;
    margin-top: 30px;
    font-size: clamp(30px, 8.9vw, 36px);
  }

  .star-banner-service-btn {
    display: none;
  }

  .star-banner-services {
    grid-template-columns: max-content max-content;
    gap: 5px 16px;
    margin-top: 17px;
    font-size: 17px;
  }

  .star-banner-services em {
    margin-right: 0;
    padding: 0;
  }

  .star-select-row {
    padding: 16px;
  }

  .star-select-row strong {
    max-width: 190px;
  }

  .rank-picker {
    grid-template-columns: 76px minmax(0, 1fr);
  }

  .rank-options,
  .hero-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .star-pay-footer {
    grid-template-columns: minmax(0, 1fr);
  }
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  font-family: "HarmonyOS Sans SC", "MiSans", "PingFang SC", "Microsoft YaHei", sans-serif;
  color: var(--text);
  background:
    radial-gradient(circle at 10% -10%, rgba(22, 199, 161, 0.24), transparent 34%),
    radial-gradient(circle at 98% 6%, rgba(242, 109, 61, 0.16), transparent 28%),
    linear-gradient(180deg, #fbf7ef 0%, #eef7f4 48%, #f6f3ed 100%);
  min-height: 100vh;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  opacity: 0.38;
  background-image:
    linear-gradient(rgba(11, 23, 38, 0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(11, 23, 38, 0.035) 1px, transparent 1px);
  background-size: 42px 42px;
  mask-image: linear-gradient(to bottom, #000 0%, transparent 76%);
}

a {
  color: inherit;
  text-decoration: none;
}

button,
input,
textarea,
select {
  font: inherit;
}

button {
  cursor: pointer;
}

.page {
  width: min(1240px, 100%);
  margin: 0 auto;
  padding: 24px 20px 64px;
  position: relative;
}

.entry-home {
  min-height: calc(100vh - 88px);
  display: grid;
  align-content: center;
  gap: 24px;
  width: 100%;
  min-width: 0;
}

.entry-brand {
  width: min(680px, 100%);
}

.entry-kicker {
  display: inline-flex;
  width: fit-content;
  border-radius: 999px;
  padding: 8px 12px;
  color: #0b1726;
  background: linear-gradient(135deg, #fff5cf 0%, #9ff2d9 100%);
  font-size: 13px;
  font-weight: 950;
}

.entry-brand h1,
.playmate-top h1 {
  margin: 16px 0 0;
  color: var(--ink);
  font-size: clamp(34px, 6vw, 58px);
  line-height: 1.04;
  letter-spacing: -0.05em;
}

.entry-brand p,
.playmate-top p {
  margin: 12px 0 0;
  max-width: 560px;
  color: var(--text-soft);
  line-height: 1.75;
}

.entry-choice-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  width: 100%;
  min-width: 0;
}

.entry-choice-card {
  position: relative;
  min-width: 0;
  min-height: 260px;
  display: grid;
  align-content: space-between;
  overflow: hidden;
  border-radius: 30px;
  padding: 24px;
  color: #fff;
  box-shadow: 0 20px 52px rgba(7, 19, 31, 0.18);
}

.entry-choice-card::after {
  content: "";
  position: absolute;
  right: -50px;
  bottom: -70px;
  width: 180px;
  height: 180px;
  border-radius: 50%;
  border: 34px solid rgba(255, 255, 255, 0.1);
}

.entry-choice-card.play-card {
  background:
    radial-gradient(circle at 18% 18%, rgba(22, 199, 161, 0.38), transparent 25%),
    linear-gradient(135deg, #07131f 0%, #0b735f 100%);
}

.entry-choice-card.boost-card {
  background:
    radial-gradient(circle at 78% 18%, rgba(242, 188, 87, 0.36), transparent 24%),
    linear-gradient(135deg, #17205d 0%, #087361 100%);
}

.entry-choice-card.lucky-card {
  background:
    radial-gradient(circle at 70% 22%, rgba(255, 229, 136, 0.42), transparent 24%),
    linear-gradient(135deg, #422100 0%, #0c8f79 100%);
}

.entry-choice-mark,
.entry-choice-card strong,
.entry-choice-card em,
.entry-choice-action {
  position: relative;
  z-index: 1;
}

.entry-choice-mark {
  width: fit-content;
  border-radius: 999px;
  padding: 7px 10px;
  background: rgba(255, 255, 255, 0.14);
  color: rgba(255, 255, 255, 0.86);
  font-size: 12px;
  font-weight: 950;
  letter-spacing: 0.08em;
}

.entry-choice-card strong {
  margin-top: 34px;
  font-size: clamp(28px, 5vw, 44px);
  line-height: 1.05;
  letter-spacing: -0.05em;
}

.entry-choice-card em {
  display: block;
  margin-top: 10px;
  color: rgba(255, 255, 255, 0.76);
  font-style: normal;
  font-weight: 700;
}

.entry-choice-action {
  width: fit-content;
  margin-top: 28px;
  border-radius: 999px;
  padding: 11px 18px;
  color: #07372f;
  background: linear-gradient(135deg, #fff5cf 0%, #71f4dd 100%);
  font-weight: 950;
}

.playmate-top {
  display: none;
  margin-bottom: 18px;
  padding: 22px;
  border-radius: 30px;
  background:
    radial-gradient(circle at 92% 12%, rgba(22, 199, 161, 0.17), transparent 25%),
    rgba(255, 255, 255, 0.78);
  border: 1px solid rgba(255, 255, 255, 0.7);
  box-shadow: var(--shadow-soft);
  backdrop-filter: blur(18px);
}

.back-home-link {
  display: inline-flex;
  width: fit-content;
  margin-bottom: 16px;
  border-radius: 999px;
  padding: 9px 13px;
  color: var(--brand);
  background: #eef8f5;
  font-size: 13px;
  font-weight: 950;
}

.hero {
  position: relative;
  overflow: hidden;
  color: #fff;
  border-radius: 34px;
  padding: 30px;
  box-shadow: 0 26px 60px rgba(7, 19, 31, 0.28);
  background:
    radial-gradient(circle at 84% 12%, rgba(242, 188, 87, 0.42), transparent 18%),
    radial-gradient(circle at 10% 14%, rgba(22, 199, 161, 0.42), transparent 24%),
    linear-gradient(135deg, #07131f 0%, #102b3b 48%, #0b735f 100%);
}

.hero::after {
  content: "";
  position: absolute;
  right: -80px;
  bottom: -110px;
  width: 270px;
  height: 270px;
  border-radius: 50%;
  border: 46px solid rgba(255, 255, 255, 0.08);
}

.hero-top,
.hero-meta,
.hero-steps {
  position: relative;
  z-index: 1;
}

.hero-top {
  display: flex;
  justify-content: space-between;
  gap: 24px;
  align-items: flex-start;
}

.hero-kicker {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  border-radius: 999px;
  padding: 8px 12px;
  margin-bottom: 14px;
  color: #0b1726;
  background: linear-gradient(135deg, #fff5cf 0%, #9ff2d9 100%);
  font-size: 13px;
  font-weight: 800;
}

.hero-title {
  font-size: clamp(34px, 5vw, 58px);
  line-height: 1.06;
  letter-spacing: -0.04em;
  font-weight: 900;
  margin: 0;
  max-width: 760px;
}

.hero-subtitle {
  margin: 14px 0 0;
  max-width: 760px;
  color: rgba(255, 255, 255, 0.78);
  line-height: 1.8;
}

.hero-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
  border: 1px solid rgba(255, 255, 255, 0.18);
  padding: 12px 18px;
  border-radius: 999px;
  color: #fff;
  background: rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(12px);
}

.front-admin-link {
  display: none;
}

.trust-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-top: 16px;
}

.trust-item {
  min-height: 88px;
  padding: 16px;
  border: 1px solid rgba(255, 255, 255, 0.72);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.76);
  box-shadow: 0 10px 24px rgba(16, 25, 40, 0.06);
  backdrop-filter: blur(16px);
}

.trust-item strong,
.trust-item span {
  display: block;
}

.trust-item strong {
  color: var(--ink);
  font-size: 16px;
  font-weight: 950;
}

.trust-item span {
  margin-top: 8px;
  color: var(--text-soft);
  font-size: 13px;
  line-height: 1.55;
  word-break: break-word;
}

.hero-steps {
  margin-top: 26px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  max-width: 720px;
}

.step-pill {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.13);
}

.step-pill strong {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: #fff;
  color: var(--brand);
}

.step-pill span {
  font-weight: 800;
}

.hero-meta {
  margin-top: 18px;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 9px 13px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(255, 255, 255, 0.1);
  color: #fff;
  font-size: 13px;
  font-weight: 700;
}

.layout {
  display: grid;
  grid-template-columns: 380px 1fr;
  gap: 20px;
  margin-top: 20px;
  align-items: start;
}

body.booking-page .page {
  width: min(820px, 100%);
}

body:not(.landing-page) .entry-home {
  display: none;
}

body.landing-page .hero,
body.landing-page .trust-strip,
body.landing-page .boost-entry-panel,
body.landing-page .layout,
body.landing-page .mobile-sticky-cta,
body.landing-page .site-footer {
  display: none;
}

body.playmate-page .hero,
body.playmate-page .trust-strip,
body.playmate-page .boost-entry-panel,
body.playmate-page .panel-login,
body.playmate-page .panel-booking,
body.playmate-page .panel-orders,
body.playmate-page .mobile-sticky-cta {
  display: none;
}

body.playmate-page .playmate-top {
  display: block;
}

body.playmate-page .layout {
  grid-template-columns: 1fr;
  margin-top: 0;
}

body.playmate-page .layout > aside {
  display: none;
}

body.playmate-page .stack {
  display: block;
}

body.playmate-page .panel-playmates {
  max-width: 860px;
  margin: 0 auto;
}

body.booking-page .hero,
body.booking-page .trust-strip,
body.booking-page .boost-entry-panel,
body.booking-page .playmate-top,
body.booking-page .panel-playmates {
  display: none;
}

body.booking-page .layout {
  grid-template-columns: 1fr;
  margin-top: 0;
}

body.booking-page .stack {
  gap: 16px;
}

body.booking-page .panel-booking {
  order: 1;
}

body.booking-page .panel-login {
  order: 2;
}

body.booking-page .panel-booking::before {
  content: "预约详情";
  display: block;
  margin-bottom: 10px;
  color: var(--brand);
  font-size: 13px;
  font-weight: 950;
  letter-spacing: 0.14em;
}

.inline-return-link {
  display: inline-flex;
  margin-top: 8px;
  color: var(--brand);
  font-size: 13px;
  font-weight: 900;
}

.stack {
  display: grid;
  gap: 20px;
}

.panel {
  background: var(--surface);
  border: 1px solid rgba(255, 255, 255, 0.72);
  border-radius: var(--radius);
  padding: 22px;
  box-shadow: var(--shadow-soft);
  backdrop-filter: blur(18px);
}

.panel-title {
  margin: 0 0 14px;
  font-size: 24px;
  line-height: 1.18;
  font-weight: 900;
  letter-spacing: -0.02em;
}

.panel-subtitle {
  margin: -4px 0 16px;
  color: var(--text-soft);
  line-height: 1.75;
  font-size: 14px;
}

.form-grid {
  display: grid;
  gap: 13px;
}

.booking-guide {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: -2px 0 15px;
}

.booking-guide span {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 7px 10px;
  border-radius: 999px;
  background: #fff4df;
  color: #9b6411;
  font-size: 12px;
  font-weight: 900;
}

.agreement-check {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  padding: 13px 14px;
  border-radius: 18px;
  background: #fff;
  border: 1px solid rgba(18, 30, 48, 0.08);
  color: var(--text-soft);
  font-size: 13px;
  line-height: 1.7;
}

.agreement-check input {
  flex: 0 0 auto;
  width: 18px;
  height: 18px;
  margin-top: 2px;
  accent-color: var(--brand);
}

.agreement-check a,
.site-footer a,
.legal-content a {
  color: #087361;
  font-weight: 900;
}

.site-footer {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px 16px;
  margin: 22px 0 0;
  color: var(--text-soft);
  font-size: 13px;
}

.legal-page {
  max-width: 880px;
}

.legal-hero {
  color: #fff;
  border-radius: 30px;
  padding: 28px;
  background:
    radial-gradient(circle at 84% 16%, rgba(242, 188, 87, 0.34), transparent 20%),
    linear-gradient(135deg, #07131f 0%, #0b735f 100%);
  box-shadow: 0 22px 52px rgba(7, 19, 31, 0.22);
}

.legal-hero h1 {
  margin: 0;
  font-size: clamp(30px, 5vw, 48px);
  line-height: 1.12;
  letter-spacing: -0.04em;
}

.legal-hero p {
  margin: 12px 0 0;
  color: rgba(255, 255, 255, 0.76);
  line-height: 1.8;
}

.legal-content {
  margin-top: 16px;
  background: var(--surface);
  border: 1px solid rgba(255, 255, 255, 0.72);
  border-radius: 26px;
  padding: 24px;
  box-shadow: var(--shadow-soft);
}

.legal-content h2 {
  margin: 26px 0 10px;
  font-size: 20px;
}

.legal-content h2:first-child {
  margin-top: 0;
}

.legal-content p,
.legal-content li {
  color: #435064;
  line-height: 1.85;
}

.legal-content ul {
  padding-left: 20px;
}

.legal-meta {
  display: grid;
  gap: 8px;
  padding: 14px;
  border-radius: 18px;
  background: #f8f6ef;
  color: var(--text-soft);
}

.boost-entry-panel {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  margin-top: 16px;
  padding: 22px;
  border-radius: 28px;
  color: #fff;
  background:
    radial-gradient(circle at 88% 0%, rgba(242, 188, 87, 0.34), transparent 22%),
    linear-gradient(135deg, #2d1d68 0%, #0d8c88 100%);
  box-shadow: 0 18px 42px rgba(45, 29, 104, 0.2);
}

.boost-entry-panel h2 {
  margin: 8px 0 0;
  font-size: 28px;
  line-height: 1.2;
  font-weight: 950;
  letter-spacing: -0.03em;
}

.boost-entry-panel p {
  margin: 10px 0 0;
  color: rgba(255, 255, 255, 0.78);
  line-height: 1.7;
}

.boost-kicker {
  display: inline-flex;
  width: fit-content;
  padding: 7px 11px;
  border-radius: 999px;
  color: #271943;
  background: #fff5cf;
  font-size: 12px;
  font-weight: 950;
}

.star-page {
  width: min(1180px, 100%);
}

.star-hero {
  position: relative;
  overflow: hidden;
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: flex-start;
  color: #fff;
  border-radius: 34px;
  padding: 30px;
  background:
    radial-gradient(circle at 84% 10%, rgba(255, 78, 205, 0.28), transparent 18%),
    radial-gradient(circle at 8% 12%, rgba(46, 220, 255, 0.28), transparent 24%),
    linear-gradient(135deg, #080b24 0%, #271943 42%, #0b735f 100%);
  box-shadow: 0 26px 60px rgba(8, 11, 36, 0.28);
}

.star-hero::after {
  content: "";
  position: absolute;
  right: -80px;
  bottom: -100px;
  width: 260px;
  height: 260px;
  border-radius: 50%;
  border: 42px solid rgba(255, 255, 255, 0.08);
}

.star-hero-content {
  position: relative;
  z-index: 1;
}

.star-hero h1 {
  margin: 0;
  max-width: 760px;
  font-size: clamp(36px, 5vw, 60px);
  line-height: 1.05;
  letter-spacing: -0.05em;
}

.star-hero p {
  max-width: 760px;
  color: rgba(255, 255, 255, 0.78);
  line-height: 1.85;
}

.star-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 340px;
  gap: 20px;
  align-items: start;
  margin-top: 20px;
}

.type-card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 18px;
}

.type-card {
  min-height: 94px;
  padding: 16px;
  border: 1px solid rgba(18, 30, 48, 0.08);
  border-radius: 22px;
  background: #fff;
  color: var(--text);
  text-align: left;
  box-shadow: 0 8px 22px rgba(16, 25, 40, 0.05);
}

.type-card strong,
.type-card span {
  display: block;
}

.type-card strong {
  font-size: 18px;
  font-weight: 950;
}

.type-card span {
  margin-top: 8px;
  color: var(--text-soft);
  line-height: 1.55;
  font-size: 13px;
}

.type-card.is-active {
  border-color: rgba(12, 143, 121, 0.55);
  background: linear-gradient(135deg, #effbf7 0%, #fff 100%);
  box-shadow: 0 0 0 4px rgba(22, 199, 161, 0.12), 0 8px 22px rgba(16, 25, 40, 0.06);
}

.star-form {
  gap: 16px;
}

.star-section {
  padding: 16px;
  border: 1px solid rgba(18, 30, 48, 0.07);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.74);
}

.section-head h3 {
  margin: 0;
  font-size: 20px;
  line-height: 1.25;
  font-weight: 950;
}

.section-head p {
  margin: 8px 0 14px;
  color: var(--text-soft);
  line-height: 1.7;
  font-size: 13px;
}

.segmented {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 14px;
}

.segmented-btn,
.choice-pill {
  min-height: 42px;
  border: 1px solid rgba(18, 30, 48, 0.08);
  border-radius: 999px;
  background: #fff;
  color: #435064;
  font-weight: 900;
}

.segmented-btn.is-active,
.choice-pill.is-active {
  border-color: rgba(12, 143, 121, 0.52);
  background: #e8f7f2;
  color: #087361;
}

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

.choice-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
}

.choice-pill {
  padding: 9px 14px;
}

.star-summary {
  background: #eef8f5;
  color: #275c54;
}

.customer-card {
  position: sticky;
  top: 16px;
}

.wecom-qr {
  display: block;
  width: 100%;
  border-radius: 22px;
  border: 1px solid rgba(18, 30, 48, 0.08);
  background: #fff;
  box-shadow: 0 10px 24px rgba(16, 25, 40, 0.08);
}

.customer-card .btn {
  width: 100%;
  margin-top: 14px;
}

.quick-list {
  display: grid;
  gap: 10px;
}

.quick-list div {
  display: flex;
  gap: 10px;
  align-items: center;
  padding: 12px;
  border-radius: 16px;
  background: #fff;
}

.quick-list strong {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  color: #fff;
  background: var(--brand);
  flex: 0 0 auto;
}

.quick-list span {
  color: #435064;
  line-height: 1.5;
}

.star-rank-preview {
  align-self: end;
}

.field-label {
  font-size: 13px;
  font-weight: 900;
  margin-bottom: 7px;
  color: #435064;
}

.field,
.textarea,
.select {
  width: 100%;
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.78);
  border-radius: 18px;
  padding: 14px 15px;
  min-height: 48px;
  outline: none;
  transition: border-color 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
}

.field:focus,
.textarea:focus,
.select:focus {
  border-color: rgba(12, 143, 121, 0.62);
  background: #fff;
  box-shadow: 0 0 0 4px rgba(22, 199, 161, 0.13);
}

.textarea {
  min-height: 110px;
  resize: vertical;
}

.button-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.btn {
  border: 0;
  border-radius: 999px;
  padding: 12px 18px;
  min-height: 46px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 900;
  transition: transform 0.18s ease, box-shadow 0.18s ease, opacity 0.18s ease;
}

.btn:active {
  transform: scale(0.98);
}

.btn-primary {
  background: linear-gradient(135deg, var(--brand) 0%, var(--brand-2) 100%);
  color: #fff;
  box-shadow: 0 12px 24px rgba(12, 143, 121, 0.24);
}

.btn-secondary {
  background: #e8f7f2;
  color: #087361;
}

.btn-ghost {
  background: #edf0f3;
  color: #526071;
}

.btn-danger {
  background: #ffe8ed;
  color: var(--danger);
}

.muted {
  color: var(--text-soft);
}

.notice {
  padding: 14px 15px;
  border-radius: 18px;
  background: rgba(248, 246, 239, 0.92);
  color: var(--text-soft);
  line-height: 1.7;
  font-size: 14px;
  border: 1px solid rgba(18, 30, 48, 0.06);
}

.playmate-announcement {
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin: 16px 0 18px;
  padding: 18px;
  border-radius: 24px;
  border: 1px solid rgba(20, 185, 142, 0.2);
  color: #10302c;
  background:
    radial-gradient(circle at 12% 12%, rgba(255, 244, 178, 0.88), transparent 25%),
    linear-gradient(135deg, rgba(235, 255, 248, 0.95) 0%, rgba(255, 255, 255, 0.96) 52%, rgba(225, 252, 244, 0.92) 100%);
  box-shadow: 0 16px 34px rgba(18, 61, 55, 0.08);
}

.playmate-announcement::after {
  content: "";
  position: absolute;
  right: -44px;
  top: -56px;
  width: 150px;
  height: 150px;
  border-radius: 50%;
  background: rgba(18, 205, 158, 0.14);
}

.playmate-announcement div {
  position: relative;
  z-index: 1;
}

.playmate-announcement span {
  display: inline-flex;
  margin-bottom: 8px;
  padding: 5px 10px;
  border-radius: 999px;
  color: #0b7d68;
  background: rgba(13, 202, 158, 0.12);
  font-size: 12px;
  font-weight: 950;
}

.playmate-announcement strong {
  display: block;
  font-size: 19px;
  line-height: 1.3;
  font-weight: 950;
}

.playmate-announcement p {
  margin: 8px 0 0;
  color: #64727d;
  line-height: 1.55;
}

.playmate-announcement-link {
  position: relative;
  z-index: 1;
  flex: 0 0 auto;
  min-width: 104px;
  padding: 13px 18px;
  border-radius: 999px;
  color: #fff;
  background: linear-gradient(135deg, #0aa88b 0%, #19d0a5 100%);
  box-shadow: 0 12px 24px rgba(18, 190, 149, 0.26);
  font-weight: 950;
  text-align: center;
  text-decoration: none;
}

.success {
  color: var(--success);
}

.warning {
  color: var(--warning);
}

.danger {
  color: var(--danger);
}

.playmate-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}

.playmate-card {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: stretch;
  gap: 10px;
  min-height: 116px;
  padding: 14px;
  border: 1px solid rgba(18, 30, 48, 0.06);
  border-radius: 24px;
  overflow: hidden;
  background:
    radial-gradient(circle at 94% 0%, rgba(22, 199, 161, 0.12), transparent 32%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(244, 247, 255, 0.94) 100%);
  box-shadow: 0 8px 22px rgba(16, 25, 40, 0.07);
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.playmate-card:hover {
  transform: translateY(-1px);
  box-shadow: 0 14px 32px rgba(16, 25, 40, 0.11);
}

.playmate-card.is-selected {
  border-color: rgba(22, 199, 161, 0.72);
  box-shadow: 0 0 0 4px rgba(22, 199, 161, 0.12), 0 12px 28px rgba(16, 25, 40, 0.08);
}

.theme-purple { background: linear-gradient(135deg, #4c3fb6 0%, #1785b9 100%); }
.theme-rose { background: linear-gradient(135deg, #c43159 0%, #f26d3d 100%); }
.theme-blue { background: linear-gradient(135deg, #1c4f9c 0%, #21a8bd 100%); }
.theme-gold { background: linear-gradient(135deg, #7a531e 0%, #f2bc57 100%); }
.theme-cyan { background: linear-gradient(135deg, #087361 0%, #21b9d0 100%); }

.banner-label {
  display: inline-flex;
  border-radius: 999px;
  padding: 7px 10px;
  font-size: 12px;
  font-weight: 900;
  color: rgba(255, 255, 255, 0.9);
  background: rgba(255, 255, 255, 0.13);
}

.avatar {
  flex: 0 0 auto;
  width: 76px;
  height: 76px;
  border-radius: 50%;
  background:
    radial-gradient(circle at 30% 20%, rgba(255, 255, 255, 0.82), rgba(22, 199, 161, 0.18)),
    linear-gradient(135deg, rgba(12, 143, 121, 0.18), rgba(242, 188, 87, 0.18));
  border: 1px solid rgba(18, 30, 48, 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  font-weight: 950;
  overflow: hidden;
  color: var(--brand);
  box-shadow: 0 8px 18px rgba(16, 25, 40, 0.11);
}

.avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.playmate-card-main {
  min-width: 0;
  display: grid;
  grid-template-columns: 76px minmax(0, 1fr) auto;
  gap: 16px;
  align-items: center;
  padding: 0;
  border: 0;
  background: transparent;
  color: inherit;
  text-align: left;
}

.playmate-name-row {
  display: flex;
  align-items: center;
  gap: 6px;
}

.playmate-name {
  margin: 0;
  font-size: 21px;
  line-height: 1.16;
  font-weight: 950;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.playmate-title {
  margin-top: 6px;
  color: var(--text-soft);
  font-size: 13px;
  line-height: 1.35;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.playmate-arrow {
  color: #8a93a3;
  font-size: 26px;
  line-height: 1;
  transform: translateY(-1px);
}

.price {
  color: var(--accent);
  font-size: 20px;
  font-weight: 950;
  white-space: nowrap;
}

.price span {
  margin-left: 2px;
  color: var(--text-soft);
  font-size: 12px;
  font-weight: 800;
}

.playmate-card-side {
  display: grid;
  gap: 8px;
  justify-items: end;
  align-content: center;
}

.playmate-status {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 5px 9px;
  background: rgba(242, 188, 87, 0.18);
  color: #9a6510;
  font-size: 12px;
  font-weight: 900;
}

.playmate-mini-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin-top: 10px;
}

.playmate-mini-tags span {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  border: 1px solid rgba(22, 199, 161, 0.72);
  border-radius: 6px;
  padding: 3px 8px;
  color: var(--brand);
  background: rgba(255, 255, 255, 0.62);
  font-size: 12px;
  font-weight: 850;
}

.tag-row {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin-top: 14px;
}

.tag {
  background: #eef8f5;
  color: #087361;
  border-radius: 999px;
  padding: 7px 10px;
  font-size: 12px;
  font-weight: 800;
  max-width: 100%;
  word-break: break-word;
}

.playmate-card-cta {
  align-self: end;
  justify-self: end;
  min-width: 104px;
  min-height: 48px;
  border: 0;
  border-radius: 18px;
  padding: 10px 16px;
  color: #07372f;
  background: linear-gradient(135deg, #a8fff1 0%, #5ce7d0 100%);
  box-shadow: 0 10px 18px rgba(22, 199, 161, 0.24);
  font-size: 17px;
  font-weight: 950;
  white-space: nowrap;
}

.playmate-modal {
  position: fixed;
  inset: 0;
  z-index: 80;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}

.playmate-modal.hidden {
  display: none;
}

.playmate-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(7, 19, 31, 0.58);
  backdrop-filter: blur(8px);
}

.playmate-modal-panel {
  position: relative;
  z-index: 1;
  width: min(560px, 100%);
  max-height: min(760px, calc(100vh - 40px));
  overflow: auto;
  border-radius: 28px;
  background: #fff;
  box-shadow: 0 28px 70px rgba(7, 19, 31, 0.26);
}

.playmate-modal-close {
  position: absolute;
  z-index: 2;
  top: 14px;
  right: 14px;
  width: 38px;
  height: 38px;
  border: 0;
  border-radius: 50%;
  color: #fff;
  background: rgba(7, 19, 31, 0.32);
  font-size: 25px;
  line-height: 1;
}

.playmate-detail-head {
  min-height: 190px;
  display: grid;
  grid-template-columns: 92px minmax(0, 1fr);
  gap: 18px;
  align-items: end;
  padding: 34px 28px 26px;
  color: #fff;
}

.playmate-detail-head .avatar {
  width: 92px;
  height: 92px;
  border-color: rgba(255, 255, 255, 0.3);
  background: rgba(255, 255, 255, 0.2);
}

.playmate-detail-head h2 {
  margin: 14px 0 8px;
  font-size: 32px;
  line-height: 1.05;
}

.playmate-detail-head p {
  margin: 0;
  color: rgba(255, 255, 255, 0.86);
  line-height: 1.6;
}

.playmate-detail-body {
  padding: 22px 24px 26px;
}

.playmate-detail-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.playmate-detail-stats span,
.playmate-detail-list span {
  border-radius: 999px;
  padding: 7px 10px;
  background: #eef8f5;
  color: var(--brand);
  font-size: 13px;
  font-weight: 900;
}

.playmate-detail-intro {
  margin: 16px 0 0;
  color: var(--text-soft);
  line-height: 1.8;
}

.playmate-detail-block {
  margin-top: 18px;
  display: grid;
  gap: 10px;
}

.playmate-detail-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.playmate-detail-block ul {
  margin: 0;
  padding-left: 20px;
  color: var(--text-soft);
  line-height: 1.8;
}

.playmate-detail-submit {
  width: 100%;
  margin-top: 22px;
}

.modal-open {
  overflow: hidden;
}

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

.slot-item {
  padding: 13px;
  border: 1px solid rgba(18, 30, 48, 0.09);
  border-radius: 18px;
  background: #fff;
  box-shadow: 0 8px 18px rgba(16, 25, 40, 0.05);
  transition: border-color 0.18s ease, background 0.18s ease, transform 0.18s ease;
}

.slot-item.selected {
  border-color: rgba(12, 143, 121, 0.58);
  background: #effbf7;
}

.slot-item input {
  width: 20px;
  height: 20px;
  accent-color: var(--brand);
}

.slot-item.disabled {
  opacity: 0.56;
  background: #f4f4f2;
}

.order-list,
.admin-list {
  display: grid;
  gap: 14px;
}

.order-card,
.admin-card {
  border: 1px solid var(--line);
  border-radius: 22px;
  padding: 16px;
  background: #fff;
  box-shadow: 0 8px 22px rgba(16, 25, 40, 0.05);
}

.order-card-head {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: flex-start;
}

.order-pay-note {
  margin: 14px 0 8px;
  padding: 12px 14px;
  border-radius: 16px;
  color: #087361;
  background: #e8f7f2;
  font-size: 13px;
  line-height: 1.65;
}

.order-row,
.info-row {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  padding: 8px 0;
  color: #53627b;
  font-size: 14px;
  line-height: 1.55;
}

.order-row span:last-child,
.info-row span:last-child {
  text-align: right;
  word-break: break-word;
}

.status {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  padding: 6px 11px;
  font-size: 12px;
  font-weight: 900;
  white-space: nowrap;
}

.status.pending { background: #fff4df; color: #b87612; }
.status.confirmed { background: #e8f7f2; color: #087361; }
.status.completed { background: #e8fbf4; color: #12915f; }
.status.cancelled { background: #f2f4f7; color: #8c97a8; }
.status.booked { background: #ffecef; color: #d2556e; }
.status.closed { background: #f2f4f7; color: #8c97a8; }
.status.expired { background: #f6efe4; color: #b47c22; }
.status.lead { background: #e8f7f2; color: #087361; }
.status.free { background: #e8fbf4; color: #12915f; }

.empty {
  padding: 18px;
  border-radius: 18px;
  background: rgba(248, 246, 239, 0.92);
  color: var(--text-soft);
  text-align: center;
}

.mobile-sticky-cta {
  display: none;
}

.toast {
  position: fixed;
  left: 50%;
  bottom: 28px;
  z-index: 80;
  width: min(420px, calc(100vw - 32px));
  transform: translateX(-50%);
  padding: 14px 18px;
  border-radius: 999px;
  color: #fff;
  background: rgba(11, 23, 38, 0.92);
  box-shadow: 0 16px 34px rgba(11, 23, 38, 0.24);
  text-align: center;
  font-weight: 900;
  line-height: 1.5;
  backdrop-filter: blur(14px);
}

.btn:disabled {
  cursor: not-allowed;
  opacity: 0.68;
  transform: none;
}

.top-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 18px;
}

.nav-title {
  font-size: 30px;
  font-weight: 900;
  margin: 0;
}

.nav-subtitle {
  margin: 8px 0 0;
  color: var(--text-soft);
}

.stats-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}

.today-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

.stat-card {
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: 20px;
  background: #fff;
}

.stat-value {
  font-size: 28px;
  font-weight: 900;
}

.stat-label {
  margin-top: 8px;
  color: var(--text-soft);
  font-size: 14px;
}

.ops-hints {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-top: 16px;
}

.ops-hint {
  padding: 15px;
  border-radius: 18px;
  background: #f8f6ef;
  border: 1px solid rgba(18, 30, 48, 0.07);
}

.ops-hint strong,
.ops-hint span {
  display: block;
}

.ops-hint strong {
  font-weight: 950;
  color: var(--ink);
}

.ops-hint span {
  margin-top: 7px;
  color: var(--text-soft);
  font-size: 13px;
  line-height: 1.65;
}

.table {
  width: 100%;
  border-collapse: collapse;
}

.table th,
.table td {
  padding: 12px 10px;
  border-bottom: 1px solid var(--line);
  text-align: left;
  font-size: 14px;
  vertical-align: top;
}

.table th {
  color: var(--text-soft);
  font-weight: 800;
}

.schedule-grid {
  display: grid;
  gap: 16px;
}

.count-grid,
.free-slot-list {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.count-item,
.free-slot-item {
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 14px;
  background: #fff;
}

.count-name {
  font-weight: 900;
}

.count-num {
  margin-top: 10px;
  font-size: 24px;
  font-weight: 900;
}

.schedule-card {
  border: 1px solid var(--line);
  border-radius: 20px;
  padding: 16px;
}

.schedule-slots {
  display: grid;
  gap: 10px;
  margin-top: 12px;
}

.schedule-slot {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  padding: 12px 14px;
  border-radius: 16px;
  background: #f8faff;
}

.debug-code {
  margin-top: 10px;
  color: #087361;
  font-weight: 900;
}

.hidden {
  display: none !important;
}

.admin-shortcuts {
  display: flex;
  gap: 10px;
  margin: 0 0 18px;
  overflow-x: auto;
  padding-bottom: 2px;
  scrollbar-width: none;
}

.admin-shortcuts::-webkit-scrollbar {
  display: none;
}

.admin-shortcuts a {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 10px 15px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.86);
  border: 1px solid rgba(18, 30, 48, 0.08);
  color: #435064;
  font-weight: 900;
  box-shadow: 0 8px 18px rgba(16, 25, 40, 0.05);
}

.admin-overview-head,
.admin-playmate-head,
.admin-playmate-main {
  display: flex;
  gap: 16px;
  align-items: flex-start;
}

.admin-overview-head,
.admin-playmate-head {
  justify-content: space-between;
}

.admin-playmate-main {
  align-items: center;
}

.admin-table-wrap {
  overflow: auto;
  margin-top: 16px;
  border-radius: 20px;
}

.admin-order-actions {
  min-width: 160px;
}

@media (max-width: 980px) {
  .layout {
    grid-template-columns: 1fr;
  }

  .star-layout {
    grid-template-columns: 1fr;
  }

  .customer-card {
    position: static;
  }

  .playmate-grid,
  .stats-grid,
  .count-grid,
  .free-slot-list {
    grid-template-columns: 1fr;
  }

  .trust-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .today-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .type-card-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  html,
  body {
    overflow-x: hidden;
  }

  body {
    background:
      radial-gradient(circle at 4% 0%, rgba(22, 199, 161, 0.28), transparent 34%),
      linear-gradient(180deg, #fbf7ef 0%, #eef7f4 100%);
  }

  .page {
    padding: 12px 12px calc(112px + env(safe-area-inset-bottom));
  }

  body.landing-page .page {
    width: 100vw;
    max-width: 100vw;
    overflow: hidden;
    padding-bottom: 18px;
  }

  .entry-home {
    min-height: calc(100vh - 30px);
    align-content: start;
    gap: 18px;
    justify-self: center;
    width: min(340px, calc(100vw - 48px));
    max-width: 100%;
    padding-top: 64px;
  }

  .entry-brand h1,
  .playmate-top h1 {
    font-size: 32px;
    letter-spacing: -0.04em;
  }

  .entry-brand p,
  .playmate-top p {
    font-size: 14px;
  }

  .entry-choice-grid {
    display: flex;
    width: 100%;
    max-width: 100%;
    gap: 8px;
  }

  .entry-choice-card {
    flex: 1 1 0;
    width: 0;
    min-width: 0;
    min-height: 166px;
    border-radius: 22px;
    padding: 12px;
  }

  .entry-choice-card strong {
    margin-top: 18px;
    font-size: 21px;
    letter-spacing: -0.04em;
    white-space: nowrap;
  }

  .entry-choice-card em {
    overflow: hidden;
    font-size: 11px;
    line-height: 1.5;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .entry-choice-action {
    margin-top: 16px;
    padding: 8px 13px;
    font-size: 13px;
  }

  .playmate-top {
    margin-bottom: 12px;
    padding: 18px;
    border-radius: 24px;
  }

  .hero {
    border-radius: 28px;
    padding: 22px 18px;
  }

  .boost-entry-panel {
    display: grid;
    gap: 14px;
    border-radius: 24px;
    padding: 18px;
  }

  .boost-entry-panel h2 {
    font-size: 23px;
  }

  .boost-entry-panel .btn {
    width: 100%;
  }

  .star-page {
    width: min(370px, calc(100vw - 48px));
    max-width: 100vw;
    margin: 0 auto;
    overflow: hidden;
  }

  .star-hero {
    display: block;
    border-radius: 26px;
    padding: 20px 18px;
  }

  .star-hero .hero-link {
    display: inline-flex;
    width: auto;
    min-width: 150px;
    min-height: 42px;
    justify-content: center;
    margin-top: 14px;
    color: #fff;
  }

  .star-hero h1 {
    font-size: 30px;
    max-width: 280px;
    line-height: 1.08;
  }

  .star-hero p {
    margin: 12px 0 0;
    font-size: 14px;
    line-height: 1.65;
  }

  .star-hero .hero-meta {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    margin-top: 14px;
  }

  .star-hero .chip {
    justify-content: center;
    min-width: 0;
    padding: 8px 10px;
    font-size: 12px;
    white-space: nowrap;
  }

  .star-layout {
    gap: 14px;
    margin-top: 14px;
  }

  .type-card {
    min-height: 0;
    padding: 14px;
    border-radius: 18px;
  }

  .star-section {
    padding: 14px;
    border-radius: 20px;
  }

  .field-grid {
    grid-template-columns: 1fr;
  }

  .segmented {
    grid-template-columns: 1fr;
  }

  .choice-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .choice-pill {
    width: 100%;
    padding: 9px 10px;
  }

  .hero-top {
    display: block;
  }

  .hero-link {
    display: none;
  }

  .star-hero .hero-link {
    display: inline-flex;
    width: auto;
    min-width: 150px;
    min-height: 42px;
    justify-content: center;
    margin-top: 14px;
    color: #fff;
  }

  .admin-top-nav .hero-link {
    display: inline-flex;
    width: 100%;
    margin-top: 12px;
    color: var(--text);
    background: rgba(255, 255, 255, 0.86);
    border-color: rgba(18, 30, 48, 0.08);
  }

  .hero-kicker {
    font-size: 12px;
    margin-bottom: 12px;
  }

  .hero-title {
    font-size: 34px;
    max-width: 320px;
  }

  .hero-subtitle {
    font-size: 14px;
    line-height: 1.72;
  }

  .hero-steps {
    grid-template-columns: 1fr;
    gap: 8px;
    margin-top: 18px;
  }

  .step-pill {
    padding: 10px 12px;
  }

  .hero-meta {
    gap: 8px;
  }

  .trust-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    margin-top: 12px;
  }

  .trust-item {
    min-height: 0;
    padding: 14px;
    border-radius: 20px;
  }

  .trust-item strong {
    font-size: 14px;
  }

  .trust-item span {
    font-size: 12px;
    margin-top: 6px;
  }

  .chip {
    padding: 7px 10px;
    font-size: 12px;
  }

  .layout {
    display: flex;
    flex-direction: column;
    gap: 14px;
    margin-top: 14px;
  }

  .stack {
    display: contents;
  }

  .panel {
    width: 100%;
    border-radius: 24px;
    padding: 18px;
  }

  .admin-top-nav {
    display: block;
    margin-bottom: 14px;
  }

  .nav-title {
    font-size: 28px;
  }

  .nav-subtitle {
    line-height: 1.65;
  }

  .admin-shortcuts {
    position: sticky;
    top: 0;
    z-index: 10;
    margin: 0 -12px 14px;
    padding: 10px 12px;
    background: linear-gradient(180deg, rgba(251, 247, 239, 0.96), rgba(251, 247, 239, 0.72));
    backdrop-filter: blur(16px);
  }

  .admin-shortcuts a {
    min-height: 38px;
    padding: 8px 13px;
    font-size: 13px;
  }

  .admin-overview-head,
  .admin-playmate-head {
    display: grid;
    gap: 14px;
  }

  .admin-overview-head .button-row,
  .admin-overview-head .btn {
    width: 100%;
  }

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

  .ops-hints {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .stat-card {
    padding: 14px;
    border-radius: 18px;
  }

  .stat-value {
    font-size: 22px;
    line-height: 1.2;
    word-break: break-word;
  }

  .stat-label {
    font-size: 12px;
  }

  .count-grid,
  .free-slot-list {
    grid-template-columns: 1fr;
  }

  .admin-table-wrap {
    overflow: visible;
    margin-top: 14px;
  }

  .table,
  .table thead,
  .table tbody,
  .table tr,
  .table th,
  .table td {
    display: block;
    width: 100%;
  }

  .table thead {
    display: none;
  }

  .table tr {
    margin-bottom: 14px;
    padding: 14px;
    border: 1px solid rgba(18, 30, 48, 0.08);
    border-radius: 20px;
    background: #fff;
    box-shadow: 0 8px 22px rgba(16, 25, 40, 0.05);
  }

  .table tr.empty-row {
    padding: 0;
    border: 0;
    box-shadow: none;
    background: transparent;
  }

  .table td {
    display: grid;
    grid-template-columns: 82px minmax(0, 1fr);
    gap: 12px;
    align-items: start;
    padding: 9px 0;
    border-bottom: 1px solid rgba(18, 30, 48, 0.07);
    text-align: left;
    line-height: 1.6;
  }

  .table td:last-child {
    border-bottom: 0;
    padding-bottom: 0;
  }

  .table td::before {
    content: attr(data-label);
    color: var(--text-soft);
    font-size: 12px;
    font-weight: 900;
  }

  .table tr.empty-row td {
    display: block;
    padding: 0;
    border: 0;
  }

  .table tr.empty-row td::before {
    display: none;
  }

  .admin-order-actions {
    min-width: 0;
  }

  .admin-order-actions .btn {
    width: 100%;
  }

  .admin-playmate-main {
    gap: 12px;
  }

  .admin-playmate-head .price {
    justify-self: start;
  }

  .admin-card .avatar {
    width: 62px;
    height: 62px;
    font-size: 24px;
  }

  .schedule-slot {
    display: grid;
    gap: 12px;
  }

  .schedule-slot .button-row,
  .schedule-slot .btn {
    width: 100%;
  }

  .panel-playmates {
    order: 1;
  }

  .panel-booking {
    order: 2;
  }

  .panel-login {
    order: 3;
  }

  .panel-orders {
    order: 4;
  }

  .panel-title {
    font-size: 21px;
  }

  .panel-subtitle {
    font-size: 13px;
    line-height: 1.65;
  }

  .playmate-announcement {
    display: grid;
    gap: 14px;
    padding: 16px;
    border-radius: 22px;
  }

  .playmate-announcement strong {
    font-size: 18px;
  }

  .playmate-announcement-link {
    width: 100%;
  }

  .playmate-grid {
    gap: 14px;
  }

  .playmate-card {
    grid-template-columns: 1fr;
    gap: 12px;
    min-height: 112px;
    border-radius: 22px;
    padding: 12px;
  }

  .avatar {
    width: 64px;
    height: 64px;
    font-size: 24px;
  }

  .playmate-card-main {
    grid-template-columns: 64px minmax(0, 1fr);
    gap: 12px;
  }

  .playmate-card-side {
    grid-column: 1 / -1;
    display: flex;
    justify-content: space-between;
    justify-items: stretch;
    align-items: center;
    padding-left: 76px;
  }

  .playmate-name {
    font-size: 20px;
  }

  .playmate-name-row {
    display: flex;
    gap: 6px;
  }

  .price {
    font-size: 19px;
  }

  .playmate-mini-tags {
    gap: 6px;
    margin-top: 8px;
  }

  .playmate-mini-tags span {
    min-height: 22px;
    padding: 2px 7px;
    font-size: 11px;
  }

  .playmate-card-cta {
    width: 100%;
    min-height: 46px;
    border-radius: 18px;
    font-size: 17px;
  }

  .form-grid > .btn,
  .button-row .btn,
  .button-row a.btn {
    width: 100%;
  }

  .playmate-modal {
    align-items: flex-end;
    padding: 12px;
  }

  .playmate-modal-panel {
    width: 100%;
    max-height: 86vh;
    border-radius: 26px;
  }

  .playmate-detail-head {
    grid-template-columns: 74px minmax(0, 1fr);
    min-height: 156px;
    gap: 14px;
    padding: 30px 20px 22px;
  }

  .playmate-detail-head .avatar {
    width: 74px;
    height: 74px;
  }

  .playmate-detail-head h2 {
    font-size: 27px;
  }

  .playmate-detail-body {
    padding: 18px;
  }

  .slot-grid {
    grid-template-columns: 1fr;
  }

  .slot-item {
    padding: 14px;
  }

  .field,
  .textarea,
  .select {
    border-radius: 16px;
    font-size: 16px;
  }

  .agreement-check {
    font-size: 12px;
  }

  .site-footer {
    padding: 0 8px;
    margin-bottom: 8px;
  }

  .legal-page {
    padding-bottom: 28px;
  }

  .legal-hero {
    border-radius: 26px;
    padding: 22px 18px;
  }

  .legal-content {
    border-radius: 22px;
    padding: 18px;
  }

  .button-row {
    gap: 9px;
  }

  .order-row,
  .info-row {
    align-items: flex-start;
  }

  .order-card-head {
    align-items: flex-start;
  }

  .order-pay-note {
    font-size: 12px;
    margin-top: 12px;
  }

  .mobile-sticky-cta {
    position: fixed;
    left: 10px;
    right: auto;
    width: calc(100vw - 20px);
    max-width: calc(100vw - 20px);
    bottom: calc(10px + env(safe-area-inset-bottom));
    z-index: 20;
    display: grid;
    gap: 9px;
    padding: 12px;
    border: 1px solid rgba(255, 255, 255, 0.72);
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.94);
    box-shadow: 0 18px 42px rgba(16, 25, 40, 0.18);
    backdrop-filter: blur(18px);
  }

  .mobile-sticky-cta strong,
  .mobile-sticky-cta span {
    display: block;
  }

  .mobile-sticky-cta > div {
    min-width: 0;
  }

  .mobile-sticky-cta strong {
    font-size: 14px;
  }

  .mobile-sticky-cta span {
    margin-top: 3px;
    color: var(--text-soft);
    font-size: 12px;
  }

  .mobile-sticky-cta .btn {
    min-height: 44px;
    padding: 10px 14px;
    width: 100%;
    white-space: nowrap;
  }

  .mobile-sticky-cta .btn:active {
    transform: scale(0.98);
  }

  .toast {
    bottom: calc(116px + env(safe-area-inset-bottom));
    border-radius: 18px;
    font-size: 14px;
  }
}

body .star-shell {
  padding-bottom: 176px;
}

body .star-bottom-actions,
body .star-pay-footer {
  bottom: calc(84px + env(safe-area-inset-bottom));
}

@media (max-width: 640px) {
  body .mobile-sticky-cta {
    bottom: calc(84px + env(safe-area-inset-bottom));
  }
}

/* Final mobile polish: slimmer tab bar, clearer success state */
body .site-bottom-nav {
  width: min(428px, calc(100vw - 26px));
  bottom: calc(9px + env(safe-area-inset-bottom));
  gap: 4px;
  padding: 7px;
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.9);
  box-shadow: 0 12px 32px rgba(10, 28, 40, 0.14);
}

body .site-bottom-nav a {
  min-height: 48px;
  gap: 3px;
  border-radius: 17px;
  font-size: 11px;
}

body .site-bottom-nav span {
  width: 22px;
  height: 22px;
  font-size: 12px;
}

body .site-bottom-nav strong {
  font-size: 11px;
  letter-spacing: 0.02em;
}

body.landing-page .site-bottom-nav [data-nav="home"],
body.playmate-page .site-bottom-nav [data-nav="play"],
body.booking-page .site-bottom-nav [data-nav="play"],
body.star-page .site-bottom-nav [data-nav="star"],
body.lucky-page .site-bottom-nav [data-nav="lucky"],
body.orders-page .site-bottom-nav [data-nav="orders"] {
  transform: translateY(-1px);
  background:
    radial-gradient(circle at 50% 0%, rgba(255, 255, 255, 0.9), transparent 40%),
    linear-gradient(135deg, rgba(20, 209, 168, 0.22), rgba(13, 143, 117, 0.12));
}

body .star-bottom-actions,
body .star-pay-footer {
  bottom: calc(78px + env(safe-area-inset-bottom));
}

@media (max-width: 640px) {
  body .mobile-sticky-cta {
    bottom: calc(78px + env(safe-area-inset-bottom));
  }
}

.order-success-card {
  margin-bottom: 14px;
  padding: 18px;
  border-radius: 24px;
  color: #fff;
  background:
    radial-gradient(circle at 88% 18%, rgba(255, 255, 255, 0.18), transparent 24%),
    linear-gradient(135deg, #073148 0%, #0d8f75 100%);
  box-shadow: 0 14px 34px rgba(11, 42, 54, 0.16);
}

.order-success-card span {
  display: inline-flex;
  padding: 5px 10px;
  border-radius: 999px;
  color: #063f35;
  background: #d8ffe7;
  font-size: 12px;
  font-weight: 950;
}

.order-success-card h2 {
  margin: 12px 0 8px;
  color: #fff;
  font-size: 28px;
  line-height: 1.08;
}

.order-success-card p {
  margin: 0;
  color: rgba(255, 255, 255, 0.82);
  line-height: 1.7;
}

/* Experience pass: keep mobile flows clean and prevent fixed bars from covering forms. */
body.booking-page .panel-orders {
  display: none;
}

body.booking-page .mobile-sticky-cta {
  display: none;
}

body.booking-page .page {
  padding-bottom: 118px;
}

body.booking-page .panel-booking {
  padding-bottom: 20px;
}

body.booking-page .booking-guide {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

body.booking-page .booking-guide span {
  justify-content: center;
  text-align: center;
}

body.booking-page .booking-guide span:nth-child(3) {
  grid-column: 1 / -1;
}

body .site-bottom-nav {
  width: min(410px, calc(100vw - 24px));
  padding: 6px;
  border-radius: 21px;
}

body .site-bottom-nav a {
  min-height: 44px;
  border-radius: 16px;
}

body .site-bottom-nav span {
  width: 21px;
  height: 21px;
}

body .star-bottom-actions,
body .star-pay-footer {
  bottom: calc(72px + env(safe-area-inset-bottom));
  width: min(424px, calc(100vw - 24px));
  padding: 10px;
  border-radius: 22px;
}

.star-reset-btn,
.star-next-btn,
.star-contact-btn {
  min-height: 48px;
  font-size: 16px;
}

.floating-service-btn {
  top: 78px;
  right: clamp(20px, 6vw, 30px);
  width: 62px;
  height: 62px;
  border-radius: 22px;
  box-shadow: 0 14px 32px rgba(11, 30, 45, 0.14), 0 0 0 6px rgba(255, 255, 255, 0.18);
}

.floating-service-btn::after {
  inset: -3px;
  border-radius: 25px;
}

.service-orbit {
  width: 23px;
  height: 16px;
}

.floating-service-btn strong {
  font-size: 14px;
}

.floating-service-btn small {
  margin-top: 4px;
  font-size: 9px;
}

@media (max-width: 420px) {
  .floating-service-btn {
    right: 22px;
    width: 56px;
    height: 56px;
    border-radius: 20px;
  }

  .floating-service-btn::after {
    border-radius: 23px;
  }

  .floating-service-btn strong {
    font-size: 13px;
  }

  .floating-service-btn small {
    display: none;
  }
}

@media (max-width: 640px) {
  body.booking-page .panel-booking {
    padding: 16px;
    border-radius: 24px;
  }

  body.booking-page .panel-booking::before {
    margin-bottom: 6px;
    font-size: 12px;
  }

  body.booking-page .panel-title {
    font-size: 24px;
  }

  body.booking-page .panel-subtitle {
    margin-bottom: 10px;
    font-size: 12px;
    line-height: 1.55;
  }

  body.booking-page .booking-guide {
    gap: 6px;
    margin-bottom: 10px;
  }

  body.booking-page .booking-guide span {
    min-height: 28px;
    padding: 5px 8px;
    font-size: 11px;
  }

  body.booking-page .form-grid {
    gap: 10px;
  }

  body.booking-page .field-label {
    margin-bottom: 5px;
    font-size: 12px;
  }

  body.booking-page .notice {
    padding: 12px 14px;
    border-radius: 16px;
    line-height: 1.55;
  }

  body.booking-page .select,
  body.booking-page .field {
    min-height: 46px;
    padding: 11px 14px;
    border-radius: 15px;
  }

  body.booking-page .slot-grid {
    gap: 8px;
  }

  body.booking-page .slot-item {
    min-height: 62px;
    padding: 10px 12px;
    border-radius: 16px;
  }

  body.booking-page .slot-item span:first-of-type {
    font-size: 15px;
  }

  body.booking-page .slot-item span:last-of-type {
    font-size: 12px;
  }
}

/* Lucky bag storefront */
.lucky-page {
  min-height: 100vh;
  color: #101a2b;
  background:
    radial-gradient(circle at 16% 6%, rgba(255, 218, 128, 0.24), transparent 28%),
    radial-gradient(circle at 86% 12%, rgba(26, 209, 168, 0.2), transparent 30%),
    linear-gradient(180deg, #eef9f5 0%, #f8fbf9 54%, #eef6f2 100%);
}

.lucky-shell {
  width: min(480px, 100%);
  margin: 0 auto;
  padding: 18px 14px 184px;
}

.lucky-topbar {
  display: grid;
  grid-template-columns: 48px 1fr 48px;
  align-items: center;
  min-height: 58px;
  margin-bottom: 14px;
  text-align: center;
}

.lucky-back {
  display: inline-grid;
  place-items: center;
  width: 44px;
  height: 44px;
  border-radius: 18px;
  color: #0d1b2e;
  text-decoration: none;
  font-size: 34px;
  font-weight: 900;
  background: rgba(255, 255, 255, 0.74);
  box-shadow: 0 12px 28px rgba(13, 35, 50, 0.08);
}

.lucky-topbar span {
  display: block;
  color: #6b7585;
  font-size: 12px;
  font-weight: 900;
}

.lucky-topbar h1 {
  margin: 2px 0 0;
  font-size: 24px;
  letter-spacing: 0.08em;
}

.lucky-hero {
  position: relative;
  overflow: hidden;
  padding: 28px 26px;
  border-radius: 32px;
  color: #fff;
  background:
    radial-gradient(circle at 72% 22%, rgba(255, 220, 134, 0.34), transparent 18%),
    radial-gradient(circle at 88% 86%, rgba(38, 227, 184, 0.28), transparent 30%),
    linear-gradient(135deg, #071a2c 0%, #0b745f 100%);
  box-shadow: 0 24px 50px rgba(6, 54, 49, 0.22);
}

.lucky-hero::after {
  content: "";
  position: absolute;
  right: -54px;
  bottom: -86px;
  width: 220px;
  height: 220px;
  border: 34px solid rgba(255, 255, 255, 0.08);
  border-radius: 999px;
}

.lucky-kicker {
  position: relative;
  z-index: 1;
  display: inline-flex;
  padding: 8px 13px;
  border-radius: 999px;
  color: #073f36;
  font-size: 12px;
  font-weight: 1000;
  background: linear-gradient(135deg, #fff5c9, #b9ffe9);
}

.lucky-hero h2 {
  position: relative;
  z-index: 1;
  margin: 18px 0 10px;
  font-size: clamp(34px, 9vw, 48px);
  line-height: 1.05;
  letter-spacing: -0.05em;
}

.lucky-hero p {
  position: relative;
  z-index: 1;
  margin: 0;
  color: rgba(255, 255, 255, 0.78);
  font-size: 15px;
  line-height: 1.75;
}

.lucky-panel,
.lucky-summary,
.lucky-result-card {
  margin-top: 14px;
  padding: 18px;
  border: 1px solid rgba(255, 255, 255, 0.78);
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.88);
  box-shadow: 0 18px 42px rgba(17, 38, 52, 0.1);
  backdrop-filter: blur(16px);
}

.lucky-section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
}

.lucky-section-head div {
  display: flex;
  align-items: center;
  gap: 10px;
}

.lucky-section-head span {
  display: inline-grid;
  place-items: center;
  width: 30px;
  height: 30px;
  border-radius: 12px;
  color: #fff;
  font-size: 12px;
  font-weight: 1000;
  background: linear-gradient(135deg, #0d987d, #18cfaa);
}

.lucky-section-head h3,
.lucky-section-head p {
  margin: 0;
}

.lucky-section-head h3 {
  font-size: 18px;
}

.lucky-section-head p {
  color: #748093;
  font-size: 12px;
  font-weight: 800;
}

.lucky-product-list,
.lucky-date-list,
.lucky-slot-list {
  display: grid;
  gap: 10px;
}

.lucky-product,
.lucky-date,
.lucky-slot {
  border: 1px solid rgba(15, 31, 50, 0.1);
  border-radius: 20px;
  background: rgba(248, 252, 250, 0.9);
  text-align: left;
  transition: transform 0.16s ease, border-color 0.16s ease, box-shadow 0.16s ease;
}

.lucky-product {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 6px 12px;
  padding: 16px;
}

.lucky-product span,
.lucky-product strong,
.lucky-slot strong,
.lucky-date strong {
  font-weight: 1000;
}

.lucky-product strong {
  color: #d56b22;
  font-size: 18px;
}

.lucky-product small {
  grid-column: 1 / -1;
  color: #0b8e75;
  font-size: 12px;
  font-weight: 1000;
}

.lucky-product em {
  grid-column: 1 / -1;
  color: #778194;
  font-style: normal;
  font-size: 13px;
  line-height: 1.5;
}

.lucky-product.active,
.lucky-date.active,
.lucky-slot.active {
  border-color: rgba(18, 200, 162, 0.9);
  background: linear-gradient(180deg, rgba(230, 255, 247, 0.98), rgba(255, 255, 255, 0.96));
  box-shadow: 0 12px 28px rgba(18, 200, 162, 0.16);
  transform: translateY(-1px);
}

.lucky-date-list {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.lucky-date,
.lucky-slot {
  padding: 12px;
  text-align: center;
}

.lucky-date span,
.lucky-slot span {
  display: block;
  margin-top: 4px;
  color: #778194;
  font-size: 12px;
  font-weight: 800;
}

.lucky-slot-list {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-top: 12px;
}

.lucky-custom-box {
  margin-top: 12px;
  padding: 14px;
  border: 1px solid rgba(18, 200, 162, 0.22);
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(232, 255, 248, 0.96), rgba(255, 255, 255, 0.96));
}

.lucky-custom-box label {
  display: block;
  margin-bottom: 8px;
  color: #101a2b;
  font-size: 14px;
  font-weight: 1000;
}

.lucky-custom-box p,
.lucky-time-note {
  margin: 8px 0 0;
  color: #7a8494;
  font-size: 12px;
  font-weight: 800;
  line-height: 1.55;
}

.lucky-date:disabled,
.lucky-slot:disabled {
  color: #a3abb8;
  background: #f1f3f5;
  opacity: 0.74;
}

.lucky-input,
.lucky-textarea {
  width: 100%;
  border: 1px solid rgba(15, 31, 50, 0.1);
  border-radius: 20px;
  background: rgba(248, 252, 250, 0.92);
  color: #111d2f;
  font: inherit;
  font-weight: 800;
  outline: none;
}

.lucky-input {
  min-height: 52px;
  padding: 0 16px;
}

.lucky-textarea {
  min-height: 112px;
  padding: 14px 16px;
  resize: vertical;
  line-height: 1.55;
}

.lucky-textarea.small {
  min-height: 82px;
  margin-top: 10px;
}

.lucky-input:focus,
.lucky-textarea:focus {
  border-color: rgba(18, 200, 162, 0.95);
  box-shadow: 0 0 0 4px rgba(18, 200, 162, 0.12);
}

.lucky-summary {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.lucky-summary div,
.lucky-result-grid div {
  padding: 14px;
  border-radius: 20px;
  background: #f4faf8;
}

.lucky-summary span,
.lucky-result-grid span,
.lucky-result-card > span {
  display: block;
  color: #7a8494;
  font-size: 12px;
  font-weight: 900;
}

.lucky-summary strong,
.lucky-result-grid strong {
  display: block;
  margin-top: 6px;
  color: #0b8e75;
  font-size: 18px;
}

.lucky-result-card h3 {
  margin: 8px 0 4px;
  font-size: 24px;
}

.lucky-result-card p {
  margin: 0 0 14px;
  color: #7a8494;
  font-weight: 800;
}

.lucky-result-grid,
.lucky-result-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.lucky-result-actions {
  margin-top: 14px;
}

.lucky-bottom-actions {
  position: fixed;
  left: 50%;
  bottom: calc(86px + env(safe-area-inset-bottom));
  z-index: 66;
  width: min(480px, calc(100vw - 24px));
  transform: translateX(-50%);
  display: grid;
  grid-template-columns: 0.8fr 1.2fr;
  gap: 10px;
  padding: 12px;
  border: 1px solid rgba(255, 255, 255, 0.82);
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.92);
  box-shadow: 0 18px 44px rgba(10, 28, 40, 0.16);
  backdrop-filter: blur(18px);
}

.lucky-bottom-actions .btn {
  min-height: 54px;
  border-radius: 999px;
}

@media (max-width: 520px) {
  .lucky-shell {
    padding-inline: 12px;
  }

  .lucky-date-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .lucky-summary,
  .lucky-result-grid,
  .lucky-result-actions {
    grid-template-columns: 1fr;
  }
}
