.lucky-draw-page-shell {
  width: 100%;
}

.lucky-draw-app {
  display: grid;
  gap: 20px;
}

.lucky-draw-hero,
.lucky-draw-panel,
.lucky-draw-card {
  border: 1px solid hsl(var(--border));
  background: linear-gradient(180deg, hsl(var(--card)), hsl(var(--card) / 0.95));
  border-radius: 24px;
  box-shadow: 0 18px 40px hsl(var(--foreground) / 0.06);
}

.lucky-draw-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) minmax(250px, 0.8fr);
  gap: 22px;
  padding: 24px;
}

.lucky-draw-eyebrow,
.lucky-draw-card__eyebrow {
  margin: 0 0 8px;
  color: hsl(var(--muted-foreground));
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.lucky-draw-title {
  margin: 0;
  font-size: clamp(30px, 4vw, 50px);
  line-height: 1.06;
}

.lucky-draw-lead,
.lucky-draw-hint,
.lucky-draw-note,
.lucky-draw-card__desc,
.lucky-draw-subtle {
  color: hsl(var(--muted-foreground));
  line-height: 1.7;
}

.lucky-draw-hero-card {
  padding: 20px;
  border-radius: 20px;
  background: linear-gradient(145deg, hsl(var(--secondary) / 0.7), hsl(var(--accent) / 0.28));
}

.lucky-draw-hero-card p {
  margin: 0 0 10px;
  font-weight: 700;
}

.lucky-draw-hero-card ul {
  margin: 0;
  padding-left: 18px;
}

.lucky-draw-panel,
.lucky-draw-card {
  padding: 20px;
}

.lucky-draw-panel-title {
  margin-bottom: 14px;
  font-size: 15px;
  font-weight: 700;
}

.lucky-draw-grid {
  display: grid;
  gap: 14px;
}

.lucky-draw-grid--config,
.lucky-draw-config-grid {
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.lucky-draw-field {
  display: grid;
  gap: 8px;
  min-width: 0;
}

.lucky-draw-field span {
  font-size: 13px;
  font-weight: 600;
}

.lucky-draw-field input,
.lucky-draw-field textarea {
  width: 100%;
  min-width: 0;
  box-sizing: border-box;
  border: 1px solid hsl(var(--border));
  border-radius: 14px;
  background: hsl(var(--background));
  color: hsl(var(--foreground));
  padding: 12px 14px;
  font: inherit;
  resize: vertical;
}

.lucky-draw-field input:focus,
.lucky-draw-field textarea:focus {
  outline: 2px solid hsl(var(--ring) / 0.28);
  outline-offset: 1px;
}

.lucky-draw-field input[type="datetime-local"] {
  min-height: 48px;
}

.lucky-draw-checkline {
  margin-top: 12px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
}

.lucky-draw-actions,
.lucky-draw-config-actions {
  margin-top: 16px;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
  justify-content: space-between;
}

.lucky-draw-inline-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.lucky-draw-button,
.lucky-draw-card__link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0 18px;
  border: 0;
  border-radius: 999px;
  background: linear-gradient(135deg, hsl(211 93% 56%), hsl(206 85% 48%));
  color: white;
  font-weight: 700;
  text-decoration: none;
  cursor: pointer;
}

.lucky-draw-button--ghost {
  background: hsl(var(--secondary));
  color: hsl(var(--foreground));
}

.lucky-draw-linkbox {
  margin-top: 14px;
}

.lucky-draw-linkresult {
  padding: 14px 16px;
  border-radius: 16px;
  background: hsl(var(--secondary) / 0.3);
}

.lucky-draw-linkresult p {
  margin: 0 0 6px;
  font-size: 12px;
  color: hsl(var(--muted-foreground));
}

.lucky-draw-link-actions {
  margin-top: 14px;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.lucky-draw-results {
  display: grid;
  gap: 18px;
}

.lucky-draw-results-header {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 14px;
}

.lucky-draw-results-header h2,
.lucky-draw-section h3,
.lucky-draw-card__title {
  margin: 0;
}

.lucky-draw-status {
  margin: 0;
  padding: 8px 12px;
  border-radius: 999px;
  background: hsl(var(--secondary));
  font-size: 13px;
}

.lucky-draw-status[data-state="loading"] {
  background: hsl(43 96% 89%);
  color: hsl(33 90% 28%);
}

.lucky-draw-status[data-state="success"] {
  background: hsl(145 52% 90%);
  color: hsl(149 67% 24%);
}

.lucky-draw-status[data-state="error"] {
  background: hsl(0 84% 92%);
  color: hsl(0 74% 33%);
}

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

.lucky-draw-metric {
  padding: 14px;
  border-radius: 16px;
  background: hsl(var(--secondary) / 0.45);
}

.lucky-draw-metric span,
.lucky-draw-proof span,
.lucky-draw-result-meta {
  display: block;
  color: hsl(var(--muted-foreground));
  font-size: 12px;
}

.lucky-draw-metric strong {
  display: block;
  margin-top: 6px;
  font-size: 20px;
  word-break: break-word;
}

.lucky-draw-proof {
  display: grid;
  gap: 10px;
  padding: 16px;
  border-radius: 18px;
  background: hsl(var(--background) / 0.7);
}

.lucky-draw-proof p {
  margin: 0;
  display: grid;
  gap: 4px;
}

.lucky-draw-proof code {
  word-break: break-all;
  font-family: ui-monospace, SFMono-Regular, Consolas, monospace;
}

.lucky-draw-result-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 12px;
}

.lucky-draw-result-item {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  padding: 14px;
  border-radius: 16px;
  background: hsl(var(--secondary) / 0.34);
}

.lucky-draw-result-rank {
  width: 42px;
  height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: linear-gradient(135deg, hsl(355 95% 63%), hsl(26 96% 61%));
  color: white;
  font-weight: 700;
}

.lucky-draw-result-main,
.lucky-draw-result-floor,
.lucky-draw-empty {
  margin: 0;
}

.lucky-draw-result-main {
  font-size: 20px;
  font-weight: 700;
}

.lucky-draw-result-floor {
  font-size: 14px;
  font-weight: 600;
}

.lucky-draw-inline-link {
  color: hsl(var(--primary));
  text-decoration: none;
  word-break: break-all;
}

.lucky-draw-empty {
  color: hsl(var(--muted-foreground));
}

@media (max-width: 960px) {
  .lucky-draw-hero,
  .lucky-draw-grid--config,
  .lucky-draw-config-grid,
  .lucky-draw-summary-grid {
    grid-template-columns: 1fr;
  }

  .lucky-draw-results-header,
  .lucky-draw-actions,
  .lucky-draw-config-actions {
    align-items: stretch;
    flex-direction: column;
  }
}
