:root {
  --brand-primary: #054335;
  --brand-primary-strong: #043d30;
  --fg: #0f172a;
  --muted: #64748b;
  --card: #ffffff;
  --accent: var(--brand-primary);
  --accent-2: #07624b;
  --ring: rgba(5, 67, 53, .35);
  --bg: var(--brand-primary);
}
* { box-sizing: border-box; }
html, body { height: 100%; }
body {
  margin:0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background: linear-gradient(180deg, #f7faf9, #eef5f2 60%, #e7f0ec);
  color: var(--fg);
  -webkit-font-smoothing: antialiased;
}
a { color: inherit; }
.topbar {
  position: sticky;
  top: 0;
  z-index: 1000;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 12px;
  background: var(--bg);
  color: #e5e7eb;
  padding: max(10px, env(safe-area-inset-top)) 16px 12px 16px;
}
.topbar .brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-weight: 600;
  letter-spacing: .3px;
  color: inherit;
  text-decoration: none;
  line-height: 1;
}
.topbar .brand img {
  height: 34px;
  width: auto;
  display: block;
}
.topbar-toggle {
  display: none;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  margin-left: auto;
  border: none;
  border-radius: 999px;
  position: relative;
  background: rgba(255, 255, 255, .12);
  color: inherit;
  cursor: pointer;
  transition: background-color .2s ease, color .2s ease, box-shadow .2s ease;
}
.topbar-toggle::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: rgba(255, 255, 255, .18);
  transform: scale(.65);
  opacity: 0;
  transition: transform .32s cubic-bezier(.19, 1, .22, 1), opacity .28s ease;
  z-index: 0;
}
.topbar-toggle.is-open::before {
  transform: scale(1.25);
  opacity: 1;
}
.topbar-toggle:hover,
.topbar-toggle.is-open {
  background: rgba(255, 255, 255, .22);
}
.topbar-toggle:focus-visible {
  outline: 2px solid rgba(255, 255, 255, .55);
  outline-offset: 2px;
}
.topbar-toggle__icon {
  position: relative;
  display: inline-block;
  width: 22px;
  height: 16px;
  z-index: 1;
  transition: transform .38s cubic-bezier(.19, 1, .22, 1);
}
.topbar-toggle__icon span {
  position: absolute;
  left: 0;
  width: 100%;
  height: 2px;
  background: currentColor;
  border-radius: 999px;
  transform-origin: center;
  transition: transform .34s cubic-bezier(.19, 1, .22, 1), opacity .2s ease, top .34s cubic-bezier(.19, 1, .22, 1);
}
.topbar-toggle__icon span:nth-child(1) { top: 0; }
.topbar-toggle__icon span:nth-child(2) { top: 7px; }
.topbar-toggle__icon span:nth-child(3) { top: 14px; }
.topbar-toggle.is-open .topbar-toggle__icon span:nth-child(1) {
  transform: translateY(7px) rotate(45deg) scaleX(1.1);
}
.topbar-toggle.is-open .topbar-toggle__icon span:nth-child(2) {
  opacity: 0;
  transform: scaleX(0);
}
.topbar-toggle.is-open .topbar-toggle__icon span:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg) scaleX(1.1);
}
.topbar-toggle.is-open .topbar-toggle__icon {
  transform: rotate(180deg) scale(1.05);
}
.topbar-toggle.is-open .topbar-toggle__icon span {
  background: #0f172a;
}
.topbar-nav {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  flex: 1 1 auto;
  min-width: 200px;
}
.topbar-nav__link {
  color: inherit;
  text-decoration: none;
  font-weight: 500;
  padding: 6px 10px;
  border-radius: 8px;
  transition: background-color .15s ease, color .15s ease;
}
button.topbar-nav__link {
  background: none;
  border: none;
  appearance: none;
  -webkit-appearance: none;
  font: inherit;
  cursor: pointer;
}
.topbar-nav__link.is-resetting {
  opacity: .6;
  pointer-events: none;
}
.topbar-nav__link:hover {
  background: rgba(255, 255, 255, 0.12);
}
.topbar-nav__link.is-active {
  background: rgba(255, 255, 255, 0.2);
  color: #ffffff;
}
.topbar-overlay {
  position: fixed;
  inset: 0;
  background: rgba(15, 23, 42, .45);
  backdrop-filter: blur(2px);
  opacity: 0;
  pointer-events: none;
  transition: opacity .3s ease;
  z-index: 1001;
}
.topbar-overlay.is-open {
  opacity: 1;
  pointer-events: auto;
}
.topbar .env {
  font-size: 12px;
  opacity: .9;
  margin-left: auto;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  flex-wrap: wrap;
}
.topbar .env a {
  color: rgba(255, 255, 255, .85);
  text-decoration: none;
}
.topbar .env a:hover {
  text-decoration: underline;
}
.topbar a:focus-visible,
.topbar button.topbar-nav__link:focus-visible {
  outline: 2px solid rgba(255, 255, 255, .55);
  outline-offset: 2px;
}
.topbar-nav__header {
  display: none;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
}
.topbar-nav__title {
  font-weight: 600;
  letter-spacing: .5px;
  text-transform: uppercase;
  font-size: .75rem;
}
.topbar-close {
  display: none;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 8px 14px;
  border-radius: 999px;
  border: 1px solid rgba(15, 23, 42, .12);
  background: rgba(5, 67, 53, .12);
  color: #054335;
  font-weight: 600;
  letter-spacing: .4px;
  text-transform: uppercase;
  font-size: .68rem;
  cursor: pointer;
  transition: background-color .2s ease, color .2s ease, transform .2s ease;
}
.topbar-close:hover {
  background: rgba(5, 67, 53, .18);
}
.topbar-close:active {
  transform: scale(.97);
}
.topbar-close:focus-visible {
  outline: 2px solid rgba(5, 67, 53, .5);
  outline-offset: 2px;
}
.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;
}
@media (max-width: 860px) {
  .topbar {
    gap: 8px;
  }
  .topbar-nav {
    order: 3;
    width: 100%;
  }
  .topbar-nav__link {
    display: inline-flex;
    align-items: center;
    padding: 10px 12px;
    border-radius: 10px;
  }
  .topbar .env {
    order: 4;
    width: 100%;
    margin-left: 0;
    font-size: 13px;
  }
  body.topbar-nav-open {
    overflow: hidden;
  }
  body.topbar-nav-enhanced .topbar-toggle {
    display: inline-flex;
    order: 2;
  }
  body.topbar-nav-enhanced .topbar-toggle.is-open {
    background: rgba(255, 255, 255, .3);
  }
  body.topbar-nav-enhanced .topbar-nav {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    width: min(320px, 80vw);
    padding: calc(env(safe-area-inset-top) + 24px) 24px 32px;
    background: #ffffff;
    color: #0f172a;
    flex-direction: column;
    align-items: stretch;
    gap: 4px;
    transform: translateX(100%);
    transition: transform .34s ease;
    box-shadow: -16px 0 40px rgba(15, 23, 42, .3);
    z-index: 1002;
  }
  body.topbar-nav-enhanced .topbar-nav.is-open {
    transform: translateX(0);
  }
  body.topbar-nav-enhanced .topbar-nav__header {
    display: flex;
    align-items: center;
    opacity: 0;
    transform: translateY(-8px);
    transition: transform .32s ease, opacity .32s ease;
  }
  body.topbar-nav-enhanced .topbar-close {
    display: inline-flex;
  }
  body.topbar-nav-enhanced .topbar-nav.is-open .topbar-nav__header {
    opacity: 1;
    transform: translateY(0);
  }
  body.topbar-nav-enhanced .topbar-nav__link {
    display: block;
    width: 100%;
    padding: 12px 16px;
    border-radius: 12px;
    font-size: 1rem;
    color: inherit;
  }
  body.topbar-nav-enhanced .topbar-nav__link:hover {
    background: rgba(5, 67, 53, .1);
  }
  body.topbar-nav-enhanced .topbar-nav__link.is-active {
    background: rgba(5, 67, 53, .16);
    color: #054335;
  }
}

@media (min-width: 861px) {
  .topbar-overlay {
    display: none !important;
  }
}

.container { max-width: 1060px; margin: 22px auto; padding: 0 16px; }
.hero {
  background: radial-gradient(80% 170% at 10% -10%, rgba(5, 67, 53, .12), transparent 40%);
  padding: 12px 6px 10px;
}
.hero h1 { margin: 0 0 6px; }
.hero p { margin: 0; color: var(--muted); }

.card { background: var(--card); border-radius: 14px; padding: 18px; box-shadow: 0 8px 30px rgba(16,24,40,.06); margin: 18px 0; border: 1px solid rgba(2,6,23,.06); }
.card-title { margin-top: 0; }

.row { display:flex; gap:10px; align-items:center; margin: 10px 0; }
.row > label { min-width: 160px; }
.desc { white-space: pre-wrap; }
input[type=text], input[type=number], select, input[type=file], input[type=password], textarea {
  padding:10px 12px; border:1px solid #cbd5e1; border-radius:10px; width:100%;
  transition: box-shadow .15s, border-color .15s;
}
textarea { width: 100%; }
input[type=text]:focus, input[type=number]:focus, select:focus, input[type=password]:focus, textarea:focus {
  outline: none; border-color: var(--accent); box-shadow: 0 0 0 4px var(--ring);
}
button { padding:10px 14px; border:none; border-radius:10px; background:linear-gradient(180deg, var(--accent), var(--accent-2)); color:#fff; cursor:pointer; box-shadow: 0 4px 14px rgba(5,67,53,.2); }
button:hover { filter: brightness(1.03); }
button:disabled { opacity:.6; cursor: not-allowed; box-shadow: none; }
button.link { background:transparent; color: var(--accent); padding:0; box-shadow:none; }
button.ghost { background: transparent; color: var(--accent); border:1px solid var(--accent); }
button.small { padding:6px 10px; border-radius: 8px; }

details.fallback { margin-top: 12px; }
.grid-2 { display:grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.grid-3 { display:grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px; }
.grid-2 > div,
.grid-3 > div { display:flex; flex-direction:column; gap:6px; }

.tasks .task { border:1px solid #e2e8f0; border-radius:12px; padding:12px; margin:10px 0; background:#fff; }
.task-head { display:flex; justify-content:space-between; align-items:center; margin-bottom:8px; }
.task-num { font-weight:600; color:#1f2937; }
.preview { display:block; max-width: 320px; max-height: 200px; margin-top: 8px; border:1px solid #e2e8f0; border-radius:10px; }

.banner { background: rgba(5, 67, 53, .08); border: 1px solid rgba(5, 67, 53, .15); color:#0f172a; padding:10px 12px; border-radius:10px; margin-bottom: 10px; }
.pill { background:rgba(5, 67, 53, .18); color:#054335; padding: 2px 8px; border-radius:999px; font-size:12px; }

.results-panel { margin-top: 10px; padding: 10px; border:1px dashed #cbd5e1; border-radius:10px; background: #f8fafc; }
.results.products { list-style: none; padding: 0; margin: 10px 0; display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 12px; }
.product { border:1px solid #e5e7eb; border-radius: 10px; padding: 10px; background:#fff; display:flex; flex-direction: column; gap: 8px; }
.product-t { display:flex; justify-content:space-between; gap: 8px; }
.product-n { font-weight: 600; }
.product-m { color: var(--muted); }

table { width:100%; border-collapse: collapse; margin: 10px 0; border: 1px solid #e2e8f0; }
th, td { border-bottom: 1px solid #e2e8f0; padding: 10px 8px; text-align:left; }
table.slim th, table.slim td { padding: 6px 8px; }
thead th { background:#f8fafc; }

.sig { border:1px dashed #94a3b8; background:#fafafa; border-radius:8px; }

.error { color: #b91c1c; margin-left: 10px; }

.radio-group { display:flex; flex-wrap:wrap; flex-direction:row; gap:14px; padding:6px 0; align-items:center; }
.choice-control { display:inline-flex; flex-direction:column; align-items:center; gap:10px; font-weight:500; line-height:1.35; cursor:pointer; }
.choice-control input[type=radio],
.choice-control input[type=checkbox] { width:18px; height:18px; margin:0; flex:none; accent-color: var(--accent); }
.choice-control span { min-width:0; }
.choice-control .status-chip { flex:none; }
.status-chip {
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:2px 10px;
  border-radius:999px;
  font-size:.9rem;
  font-weight:600;
  border:1px solid transparent;
  background:rgba(148,163,184,.12);
  color:#0f172a;
  transition:background-color .2s ease, color .2s ease, border-color .2s ease;
}
.status-chip.status-pass {
  color:#047857;
  border-color:rgba(5,150,105,.35);
  background:rgba(16,185,129,.12);
}
.status-chip.status-fail {
  color:#b91c1c;
  border-color:rgba(239,68,68,.35);
  background:rgba(248,113,113,.12);
}
.status-chip.is-active.status-pass {
  background:#059669;
  color:#fff;
  border-color:#047857;
}
.status-chip.is-active.status-fail {
  background:#dc2626;
  color:#fff;
  border-color:#b91c1c;
}

.muted { color: #64748b; }
.asset-register-banner {
  margin: 10px 0;
  padding: 10px 12px;
  border: 1px solid #d1d5db;
  border-radius: 10px;
  background: #f8fafc;
  color: #0f172a;
}
.asset-register-banner.is-loading {
  border-color: #fbbf24;
  background: #fffbeb;
  color: #92400e;
}
.asset-register-banner.is-error {
  border-color: #fca5a5;
  background: #fff1f2;
  color: #991b1b;
}
.asset-register-banner.is-ready {
  border-color: #9ed2c2;
  background: #ecfdf3;
  color: #14532d;
}

.schema-section { margin: 16px 0; }
@media (max-width: 760px) {
  .grid-2, .grid-3 { grid-template-columns: 1fr; }
  .row { flex-direction: column; align-items: stretch; }
  .row > label { min-width: auto; }
  .radio-group { display:grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap:10px 14px; align-items:start; }
  .radio-group .choice-control { display:flex; }
}
