.aws-wheel-shell {
  --aws-bg-1: #fff8ef;
  --aws-bg-2: #f8fbff;
  --aws-card: #ffffff;
  --aws-text: #1d2433;
  --aws-muted: #64748b;
  --aws-accent: #7c3aed;
  --aws-accent-2: #ec4899;
  --aws-pointer: #ff5d5d;
  --aws-shadow: 0 20px 60px rgba(30, 41, 59, 0.18);
  font-family: Inter, Arial, Helvetica, sans-serif;
  color: var(--aws-text);
  margin: 28px auto;
}
.aws-wheel-card {
  max-width: 980px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(320px, 1fr) minmax(220px, 290px);
  gap: 26px;
  align-items: center;
  padding: 28px;
  border-radius: 30px;
  background: radial-gradient(circle at top left, rgba(255,255,255,0.95), rgba(255,255,255,0.86) 38%, rgba(255,255,255,0.93) 100%), linear-gradient(135deg, var(--aws-bg-1), var(--aws-bg-2));
  box-shadow: var(--aws-shadow);
  border: 1px solid rgba(124, 58, 237, 0.08);
}
.aws-wheel-stage { position: relative; aspect-ratio: 1 / 1; max-width: 640px; width: 100%; margin: 0 auto; }
.aws-wheel-canvas { width: 100%; height: auto; display: block; border-radius: 50%; filter: drop-shadow(0 18px 28px rgba(17, 24, 39, 0.18)); }
.aws-wheel-pointer { position: absolute; top: 8px; left: 50%; transform: translateX(-50%); width: 0; height: 0; z-index: 5; border-left: 22px solid transparent; border-right: 22px solid transparent; border-top: 42px solid var(--aws-pointer); filter: drop-shadow(0 8px 10px rgba(0, 0, 0, 0.18)); }
.aws-wheel-pointer::after { content: ""; position: absolute; left: -9px; top: -42px; width: 18px; height: 18px; border-radius: 50%; background: #ffffff; box-shadow: 0 0 0 5px var(--aws-pointer); }
.aws-wheel-center-badge { position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); width: 92px; height: 92px; border-radius: 50%; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 1px; font-weight: 900; font-size: 17px; line-height: .92; letter-spacing: .02em; text-align: center; color: #fff; background: linear-gradient(135deg, var(--aws-accent), var(--aws-accent-2)); border: 6px solid rgba(255,255,255,0.95); box-shadow: 0 14px 24px rgba(124,58,237,0.28); pointer-events: none; overflow: hidden; }
.aws-wheel-center-badge span { display: block; white-space: nowrap; }
.aws-wheel-panel { display: flex; flex-direction: column; gap: 14px; align-items: stretch; }
.aws-spin-button { appearance:none; border:0; border-radius:999px; padding:16px 22px; font-size:18px; font-weight:800; line-height:1.2; color:#fff; background:linear-gradient(135deg,var(--aws-accent),var(--aws-accent-2)); cursor:pointer; box-shadow:0 14px 26px rgba(124,58,237,.26); transition:transform .16s ease, box-shadow .16s ease, opacity .16s ease; }
.aws-spin-button:hover { transform: translateY(-1px); box-shadow:0 18px 30px rgba(124,58,237,.3); }
.aws-spin-button:disabled { opacity:.72; cursor:wait; transform:none; }
.aws-result-label { font-size:13px; text-transform:uppercase; letter-spacing:.14em; color:var(--aws-muted); font-weight:800; }
.aws-result { min-height:110px; display:flex; align-items:center; justify-content:center; text-align:center; padding:18px 20px; border-radius:22px; background:linear-gradient(180deg, rgba(255,255,255,.95), rgba(248,250,252,.96)); border:1px solid rgba(148,163,184,.22); box-shadow:inset 0 1px 0 rgba(255,255,255,.85); font-size:clamp(20px,2.2vw,32px); line-height:1.18; font-weight:900; color:#0f172a; overflow-wrap:anywhere; }
.aws-admin-wrap .aws-admin-grid { display:grid; grid-template-columns: 280px minmax(0,1fr); gap:20px; margin-top:20px; }
.aws-admin-wrap .aws-admin-card { background:#fff; border:1px solid #dcdcde; border-radius:16px; padding:20px; box-shadow:0 6px 24px rgba(0,0,0,.04); }
.aws-wheel-list { margin:0; padding:0; list-style:none; }
.aws-wheel-list li { margin:0 0 10px; }
.aws-wheel-list a { display:block; text-decoration:none; padding:12px; border-radius:12px; border:1px solid #e2e8f0; }
.aws-color-grid { display:grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap:12px; }
@media (max-width: 960px) { .aws-admin-wrap .aws-admin-grid, .aws-wheel-card { grid-template-columns:1fr; } }
@media (max-width: 520px) {
  .aws-wheel-card { padding: 16px; gap: 18px; border-radius: 22px; }
  .aws-wheel-pointer { top: 4px; border-left-width: 16px; border-right-width: 16px; border-top-width: 30px; }
  .aws-wheel-pointer::after { top: -31px; }
  .aws-wheel-center-badge { width: 78px; height: 78px; font-size: 14px; border-width: 5px; }
}
