*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

body {
  font-family: ui-monospace, "SF Mono", "Cascadia Code", "Consolas", monospace;
  font-size: 13px;
  background: #f5f5f5;
  color: #1a1a1a;
  padding: 24px;
}

h1 { font-size: 18px; font-weight: 700; margin-bottom: 4px; }
.subtitle { color: #666; font-size: 12px; margin-bottom: 32px; }

section { margin-bottom: 36px; }
h2 { font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: #555; margin-bottom: 12px; border-bottom: 1px solid #ddd; padding-bottom: 6px; }

.card {
  background: #fff;
  border: 1px solid #e0e0e0;
  border-radius: 6px;
  padding: 16px 20px;
}

.card.aws-card {
  display: flex;
  align-items: center;
  gap: 20px;
}

.card .label { font-size: 11px; color: #888; text-transform: uppercase; letter-spacing: 0.06em; }
.card .value { font-size: 20px; font-weight: 700; margin-top: 2px; }
.card .meta { font-size: 11px; color: #999; margin-top: 4px; }

.aws-link {
  display: inline-block;
  margin-left: auto;
  background: #232f3e;
  color: #fff;
  text-decoration: none;
  padding: 7px 14px;
  border-radius: 4px;
  font-size: 12px;
  white-space: nowrap;
}
.aws-link:hover { background: #374151; }

.error-banner {
  background: #fff3cd;
  border: 1px solid #ffc107;
  border-radius: 4px;
  padding: 8px 12px;
  font-size: 12px;
  color: #856404;
  margin-bottom: 16px;
}

table { width: 100%; border-collapse: collapse; background: #fff; border: 1px solid #e0e0e0; border-radius: 6px; overflow: hidden; }
th { background: #f8f8f8; text-align: left; padding: 8px 12px; font-size: 11px; text-transform: uppercase; letter-spacing: 0.06em; color: #555; border-bottom: 1px solid #e0e0e0; font-weight: 600; }
td { padding: 8px 12px; border-bottom: 1px solid #f0f0f0; vertical-align: middle; }
tr:last-child td { border-bottom: none; }
tr:hover td { background: #fafafa; }

.num { text-align: right; font-variant-numeric: tabular-nums; }
.tag { display: inline-block; background: #eef0ff; color: #3730a3; font-size: 10px; padding: 1px 6px; border-radius: 3px; }
.tag.bedrock { background: #fef3c7; color: #92400e; }

a { color: #1d4ed8; text-decoration: none; }
a:hover { text-decoration: underline; }

.empty { color: #999; font-style: italic; padding: 12px; text-align: center; }
.footer { margin-top: 40px; font-size: 11px; color: #aaa; }
