/* You Ticket provider theme */
.provider-yticket {
  --yticket-blue: #1a66b3;
  --yticket-blue-dark: #155a9e;
  --yticket-blue-light: #4a8fd4;
  --yticket-blue-muted: #eef4fa;
}

.provider-yticket .ticket-section-btn {
  border-color: #e8dff0;
  background: #faf7fc;
}

.provider-yticket .ticket-section-btn:hover:not(:disabled),
.provider-yticket .ticket-section-btn:focus:not(:disabled),
.provider-yticket .ticket-section-btn.is-highlighted {
  border-color: var(--yticket-blue);
  color: var(--yticket-blue);
  background: var(--yticket-blue-muted);
}

.provider-yticket .ticket-section-btn:disabled {
  background: #f5f5f5;
}

.provider-yticket .ticket-zone-btn {
  color: var(--yticket-blue);
  border-color: var(--yticket-blue);
}

.provider-yticket .ticket-zone-btn:hover {
  background: var(--yticket-blue-muted);
}

.provider-yticket .ticket-complete-btn:not(:disabled) {
  background: linear-gradient(135deg, var(--yticket-blue) 0%, var(--yticket-blue-dark) 100%);
}

.provider-yticket .ticket-complete-btn:not(:disabled):hover {
  background: linear-gradient(135deg, var(--yticket-blue-light) 0%, var(--yticket-blue) 100%);
}

.provider-yticket .ticket-round-badge {
  border-color: var(--yticket-blue);
}

.provider-yticket .ticket-round-value span {
  color: var(--yticket-blue);
}

.provider-yticket .ticket-split-panel-yticket {
  border-top-color: #e8dff0;
}

.provider-yticket .ticket-section-panel-full {
  flex: 1;
  width: 100%;
}

.venue-svg-yticket .venue-section .section-rect {
  fill: white;
  stroke: #999999;
}

.venue-svg-yticket .venue-section:hover .section-rect,
.venue-svg-yticket .venue-section:focus .section-rect,
.venue-svg-yticket .venue-section.section-highlight .section-rect {
  stroke-width: 2.5;
}

.venue-svg-yticket .venue-section .section-sublabel {
  fill: #f5eef9;
}

/* You Ticket seat selection screen */
.provider-yticket .ticket-main-yticket-seat {
  padding-bottom: 56px;
}

.yticket-sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.yticket-seat-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 14px;
  background: #2d313a;
  color: #ffffff;
}

.yticket-seat-timer {
  flex-shrink: 0;
  font-size: 14px;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  color: #ffffff;
}

.yticket-seat-back {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border: 1px solid rgba(255, 255, 255, 0.25);
  border-radius: 4px;
  background: transparent;
  color: #ffffff;
  font-size: 14px;
  cursor: pointer;
  padding: 0;
}

.yticket-seat-back:hover {
  background: rgba(255, 255, 255, 0.08);
}

.yticket-seat-breadcrumb {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
}

.yticket-seat-step-muted {
  color: rgba(255, 255, 255, 0.55);
}

.yticket-seat-step-sep {
  color: rgba(255, 255, 255, 0.35);
  font-size: 16px;
}

.yticket-seat-step-current {
  font-weight: 700;
}

.yticket-seat-actionbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 14px;
  background: #f3f3f3;
  border-bottom: 1px solid #e0e0e0;
}

.yticket-seat-prompt {
  margin: 0;
  font-size: 13px;
  font-weight: 600;
  color: #333333;
}

.yticket-next-btn {
  flex-shrink: 0;
  min-width: 72px;
  padding: 8px 18px;
  border: none;
  border-radius: 4px;
  background: var(--yticket-blue);
  color: #ffffff;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.04em;
  cursor: pointer;
}

.yticket-next-btn:disabled {
  background: #a8c4e0;
  cursor: not-allowed;
}

.yticket-next-btn:not(:disabled):hover {
  background: var(--yticket-blue-dark);
}

.provider-yticket .yticket-seat-wrap {
  flex: 1;
  min-height: 0;
  background: #ffffff;
}

.provider-yticket #section-view #seatmap-container {
  overflow: hidden;
  align-items: center;
  justify-content: center;
}

.practice-page .provider-yticket #section-view.ticket-main-yticket-seat {
  flex: 1;
  min-height: 0;
  overflow: hidden;
}

.practice-page .provider-yticket .yticket-seat-wrap {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.provider-yticket #section-view .seat,
.provider-yticket #section-view .available-seat,
.provider-yticket #section-view .empty-block {
  width: 10px;
  height: 10px;
  margin-right: 1px;
  margin-bottom: 1px;
  box-sizing: border-box;
  flex-shrink: 0;
}

.provider-yticket #section-view .seat,
.provider-yticket #section-view .available-seat {
  border: 1px solid #cccccc;
  border-radius: 1px;
  background-color: #ffffff;
  position: relative;
  cursor: default;
}

.provider-yticket #section-view .seat {
  background-color: #f0f0f0;
  border-color: #dddddd;
}

.provider-yticket #section-view .available-seat {
  background-color: var(--yticket-blue);
  border-color: var(--yticket-blue);
  cursor: pointer;
}

.provider-yticket #section-view .available-seat:hover {
  background-color: var(--yticket-blue-dark);
  border-color: var(--yticket-blue-dark);
}

.provider-yticket #section-view .available-seat.selected-seat {
  background-color: #000000;
  border: 1px solid #000000;
}

.provider-yticket #section-view .available-seat.selected-seat::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -40%);
  width: 0;
  height: 0;
  border-left: 2px solid transparent;
  border-right: 2px solid transparent;
  border-top: 2px solid #ffffff;
  pointer-events: none;
}

.queue-modal-yticket .queue-modal-card-yticket {
  position: relative;
  width: 100%;
  max-width: 340px;
  padding: 28px 24px 20px;
  border: 1px solid #333333;
  border-radius: 0;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.12);
  text-align: center;
}

.queue-modal-yticket-close {
  position: absolute;
  top: 10px;
  right: 12px;
  border: none;
  background: transparent;
  color: #999999;
  font-size: 22px;
  line-height: 1;
  padding: 4px;
  cursor: not-allowed;
}

.queue-modal-yticket-logo {
  margin-bottom: 20px;
  font-size: 22px;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: #1a1a1a;
}

.queue-modal-yticket-heading {
  margin: 0 0 8px;
  font-size: 18px;
  font-weight: 700;
  color: #1a1a1a;
}

.queue-modal-yticket-sub {
  margin: 0 0 20px;
  font-size: 13px;
  line-height: 1.5;
  color: #888888;
}

.queue-modal-yticket-statusbox {
  margin: 0 0 16px;
  padding: 16px 14px 14px;
  background: #f0f0f0;
  border-radius: 4px;
}

.queue-modal-yticket-line {
  margin: 0;
  font-size: 14px;
  color: #333333;
}

.queue-modal-yticket-number {
  display: inline-block;
  margin-left: 4px;
  font-size: 22px;
  font-weight: 800;
  color: var(--yticket-blue);
  text-decoration: underline;
  text-underline-offset: 3px;
  transition: transform 0.15s ease;
}

.queue-modal-yticket-number.is-ticking {
  transform: scale(1.06);
}

.queue-modal-yticket-plus {
  display: block;
  margin: 6px 0 12px;
  font-size: 16px;
  font-weight: 700;
  color: var(--yticket-blue);
  line-height: 1;
}

.queue-modal-yticket-progress {
  height: 8px;
  background: #d8d8d8;
  border-radius: 4px;
  overflow: hidden;
}

.queue-modal-yticket-progress-fill {
  height: 100%;
  width: 0%;
  background: var(--yticket-blue);
  border-radius: 4px;
  transition: width 0.4s ease;
}

.queue-modal-yticket-status-sr {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.queue-modal-yticket-warning {
  margin: 0;
  font-size: 11px;
  line-height: 1.5;
  color: #888888;
}

.queue-modal-yticket-warning::before {
  content: "※ ";
}

/* Round success toast */
.provider-yticket .round-success-icon {
  background: rgba(26, 102, 179, 0.85);
}

.provider-yticket .round-success-text {
  color: var(--yticket-blue);
}

/* Payment conflict notice */
.notice-modal-yticket .notice-modal-card-yticket {
  width: 100%;
  max-width: 360px;
  padding: 0;
  border: 1px solid #6a8fa8;
  border-radius: 8px;
  overflow: hidden;
  background: #f5f5f5;
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.18);
  text-align: left;
}

.notice-modal-yticket-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 10px 8px 14px;
  background: var(--yticket-blue);
  color: #ffffff;
}

.notice-modal-yticket-header-title {
  font-size: 13px;
  font-weight: 600;
}

.notice-modal-yticket-close {
  border: none;
  background: transparent;
  color: #ffffff;
  font-size: 18px;
  line-height: 1;
  padding: 2px 6px;
  cursor: pointer;
}

.notice-modal-yticket-close:hover {
  opacity: 0.85;
}

.notice-modal-yticket-body {
  padding: 28px 20px 24px;
  text-align: center;
  background: #f5f5f5;
}

.notice-modal-yticket-title {
  margin: 0 0 10px;
  font-size: 15px;
  font-weight: 700;
  color: #1a1a1a;
}

.notice-modal-yticket-text {
  margin: 0;
  font-size: 14px;
  line-height: 1.55;
  color: #1a1a1a;
}

.notice-modal-yticket-footer {
  padding: 12px 16px 16px;
  border-top: 1px solid #d8d8d8;
  background: #f5f5f5;
  text-align: right;
}

.notice-modal-yticket-btn {
  min-width: 72px;
  padding: 6px 20px;
  border: 1px solid #8aaec4;
  border-radius: 5px;
  background: linear-gradient(180deg, #e8f2f8 0%, #d4e6f0 100%);
  color: #333333;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
}

.notice-modal-yticket-btn:hover {
  background: linear-gradient(180deg, #dcecf6 0%, #c8deec 100%);
}

/* Results screen */
.result-modal.provider-yticket .result-card-header {
  background: linear-gradient(135deg, var(--yticket-blue) 0%, var(--yticket-blue-dark) 100%);
}

.result-modal.provider-yticket .result-hero-time {
  color: var(--yticket-blue);
}

.result-modal.provider-yticket .result-level {
  color: var(--yticket-blue-dark);
}

.result-modal.provider-yticket .result-stat {
  background: var(--yticket-blue-muted);
  border-color: #d4e6f0;
}

.result-modal.provider-yticket .result-stat-best-score {
  background: #f3f4f6;
  border-color: #e5e7eb;
}

.result-modal.provider-yticket .result-stat-best-score.is-new-record {
  background: linear-gradient(135deg, #eef4fa 0%, #dbeafe 100%);
  border-color: var(--yticket-blue);
  box-shadow: 0 0 0 1px rgba(26, 102, 179, 0.15), 0 4px 14px rgba(26, 102, 179, 0.2);
}

.result-modal.provider-yticket .result-stat-best-score.is-new-record .result-stat-label {
  color: var(--yticket-blue-dark);
}

.result-modal.provider-yticket .result-stat-best-score.is-new-record .result-stat-value {
  color: var(--yticket-blue);
}
