/* ============================================================
   MustKit — component layer (BEM, token-only)
   Built on JK theme tokens. No hardcoded color/space/font/radius.
   ============================================================ */
@import url('tokens/theme.css');

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font: var(--jk-text-body);
  color: var(--jk-text);
  background: var(--jk-bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  transition: background .25s ease, color .25s ease;
}
h1, h2, h3, h4 { margin: 0; color: var(--jk-text); letter-spacing: var(--jk-text-tracking-tight); }
h1 { font: var(--jk-text-h1); }
h2 { font: var(--jk-text-h2); }
h3 { font: var(--jk-text-h3); }
h4 { font: var(--jk-text-h4); }
p { margin: 0; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
button { font-family: inherit; cursor: pointer; }
:focus-visible { outline: none; box-shadow: var(--jk-focus-ring); border-radius: var(--jk-radius-sm); }
::selection { background: var(--jk-primary-soft); }

/* ---------- layout helpers ---------- */
.container { max-width: var(--jk-content-max); margin: 0 auto; padding: 0 var(--jk-space-6); }
.section { padding: var(--jk-space-24) 0; }
.section--subtle { background: var(--jk-bg-subtle); border-block: 1px solid var(--jk-border); }
.eyebrow { font: var(--jk-text-label); letter-spacing: .09em; text-transform: uppercase; color: var(--jk-primary); }
.lead { font: var(--jk-text-body-lg); color: var(--jk-text-muted); }
.muted { color: var(--jk-text-muted); }
.center { text-align: center; }
.mono { font-family: var(--jk-mono); }
.stack { display: flex; flex-direction: column; }
.row { display: flex; align-items: center; }
.spread { display: flex; align-items: center; justify-content: space-between; gap: var(--jk-space-4); }
.wrap { flex-wrap: wrap; }
.grid { display: grid; gap: var(--jk-space-5); }
.grid--2 { grid-template-columns: repeat(2, 1fr); }
.grid--3 { grid-template-columns: repeat(3, 1fr); }
.grid--4 { grid-template-columns: repeat(4, 1fr); }

/* ============================================================
   Button
   ============================================================ */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--jk-space-2);
  font: var(--jk-text-body); font-weight: 600; border: 1px solid transparent;
  border-radius: var(--jk-radius); padding: 0 var(--jk-space-5); height: 42px; white-space: nowrap;
  transition: transform .15s ease, box-shadow .2s ease, background .2s ease, border-color .2s ease, color .2s ease;
  user-select: none;
}
.btn svg { width: 17px; height: 17px; flex: none; }
.btn--pill { border-radius: var(--jk-radius-pill); }
.btn--lg { height: 50px; padding: 0 var(--jk-space-8); font: var(--jk-text-body-lg); font-weight: 600; }
.btn--sm { height: 34px; padding: 0 var(--jk-space-3); font: var(--jk-text-sm); font-weight: 600; }
.btn--block { width: 100%; }

.btn--primary { background: var(--jk-primary); color: var(--jk-on-primary); box-shadow: var(--jk-shadow-brand); }
.btn--primary:hover { background: var(--jk-primary-hover); transform: translateY(-1px); }
.btn--primary:active { background: var(--jk-primary-active); transform: translateY(0); }
.btn--primary:disabled { background: var(--jk-disabled-bg); color: var(--jk-disabled-text); box-shadow: none; cursor: not-allowed; transform: none; }

.btn--secondary { background: var(--jk-bg-elevated); color: var(--jk-text); border-color: var(--jk-border); box-shadow: var(--jk-shadow-sm); }
.btn--secondary:hover { border-color: var(--jk-text-muted); transform: translateY(-1px); }
.btn--secondary:disabled { color: var(--jk-disabled-text); border-color: var(--jk-disabled-border); cursor: not-allowed; transform: none; }

.btn--ghost { background: transparent; color: var(--jk-text); }
.btn--ghost:hover { background: var(--jk-bg-subtle); }

.btn--danger { background: var(--jk-bg-elevated); color: var(--jk-danger); border-color: var(--jk-danger-border); }
.btn--danger:hover { background: var(--jk-danger-bg); }

.btn--google { background: var(--jk-bg-elevated); color: var(--jk-text); border-color: var(--jk-border); }
.btn--google:hover { background: var(--jk-bg-subtle); }

/* ============================================================
   Card / panel
   ============================================================ */
.card {
  background: var(--jk-bg-elevated); border: 1px solid var(--jk-border);
  border-radius: var(--jk-radius-lg); box-shadow: var(--jk-shadow-sm);
}
.card--pad { padding: var(--jk-space-6); }
.card--hover { transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease; }
.card--hover:hover { transform: translateY(-4px); box-shadow: var(--jk-shadow-lg); border-color: var(--jk-primary-soft-border); }

.panel { background: var(--jk-bg-elevated); border: 1px solid var(--jk-border); border-radius: var(--jk-radius-lg); box-shadow: var(--jk-shadow-sm); }
.panel__head { display: flex; align-items: center; justify-content: space-between; gap: var(--jk-space-4); padding: var(--jk-space-5) var(--jk-space-6); border-bottom: 1px solid var(--jk-border); }
.panel__head h3 { font: var(--jk-text-h4); }
.panel__body { padding: var(--jk-space-6); }
.panel__foot { padding: var(--jk-space-4) var(--jk-space-6); border-top: 1px solid var(--jk-border); }

/* service / product icon tile (solid brand — reads as app icon, not button) */
.svc-icon {
  width: 46px; height: 46px; border-radius: var(--jk-radius-lg); display: grid; place-items: center;
  background: var(--jk-primary); color: var(--jk-on-primary); flex: none; box-shadow: var(--jk-shadow-sm);
}
.svc-icon svg { width: 23px; height: 23px; }
.svc-icon--lg { width: 64px; height: 64px; border-radius: 16px; }
.svc-icon--lg svg { width: 31px; height: 31px; }

/* ============================================================
   Badge (status) — tinted chips, never solid (vs solid primary button)
   ============================================================ */
.badge {
  display: inline-flex; align-items: center; gap: var(--jk-space-2); height: 24px; padding: 0 var(--jk-space-3);
  font: var(--jk-text-caption); font-weight: 600; border-radius: var(--jk-radius-pill); border: 1px solid transparent;
  white-space: nowrap;
}
.badge__dot { width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.badge--active   { color: var(--jk-success-text); background: var(--jk-success-bg); border-color: var(--jk-success-border); }
.badge--trial    { color: var(--jk-warning-text); background: var(--jk-warning-bg); border-color: var(--jk-warning-border); }
.badge--expired  { color: var(--jk-danger-text);  background: var(--jk-danger-bg);  border-color: var(--jk-danger-border); }
.badge--canceled { color: var(--jk-muted-text);   background: var(--jk-muted-bg);   border-color: var(--jk-muted-border); }
.badge--paid     { color: var(--jk-success-text); background: var(--jk-success-bg); border-color: var(--jk-success-border); }
.badge--failed   { color: var(--jk-danger-text);  background: var(--jk-danger-bg);  border-color: var(--jk-danger-border); }

/* catalog type/status tag */
.tag {
  display: inline-flex; align-items: center; gap: var(--jk-space-1); height: 22px; padding: 0 var(--jk-space-2);
  font: var(--jk-text-caption); font-weight: 600; border-radius: var(--jk-radius-pill);
  background: var(--jk-muted-bg); color: var(--jk-text-muted); border: 1px solid var(--jk-border);
}
.tag__dot { width: 5px; height: 5px; border-radius: 50%; background: currentColor; }
.tag--live { color: var(--jk-success-text); background: var(--jk-success-bg); border-color: var(--jk-success-border); }
.tag--beta { color: var(--jk-warning-text); background: var(--jk-warning-bg); border-color: var(--jk-warning-border); }
.tag--soon { color: var(--jk-muted-text); background: var(--jk-muted-bg); }
.tag--pro  { color: var(--jk-primary); background: var(--jk-primary-soft); border-color: var(--jk-primary-soft-border); }

/* ============================================================
   Form field
   ============================================================ */
.field { display: flex; flex-direction: column; gap: var(--jk-space-2); margin-bottom: var(--jk-space-5); }
.field__label { font: var(--jk-text-sm); font-weight: 600; color: var(--jk-text); }
.field__input, .field__select, .field__textarea {
  width: 100%; height: 44px; padding: 0 var(--jk-space-4); font: var(--jk-text-body); color: var(--jk-text);
  background: var(--jk-bg-elevated); border: 1px solid var(--jk-border); border-radius: var(--jk-radius);
  transition: border-color .15s ease, box-shadow .15s ease;
}
.field__textarea { height: auto; padding: var(--jk-space-3) var(--jk-space-4); resize: vertical; }
.field__input:focus-visible, .field__select:focus-visible, .field__textarea:focus-visible { box-shadow: var(--jk-focus-ring); border-color: var(--jk-primary); }
.field__input::placeholder { color: var(--jk-text-muted); opacity: .65; }
.field__input:disabled { background: var(--jk-disabled-bg); border-color: var(--jk-disabled-border); color: var(--jk-disabled-text); cursor: not-allowed; }
.field__input--error { border-color: var(--jk-danger); }
.field__input--error:focus-visible { box-shadow: 0 0 0 2px var(--jk-bg), 0 0 0 4px var(--jk-danger); }
.field__help { font: var(--jk-text-caption); color: var(--jk-text-muted); }
.field__error { font: var(--jk-text-caption); font-weight: 500; color: var(--jk-danger); }
.field--icon { position: relative; }
.field--icon .field__input { padding-left: var(--jk-space-10); }
.field--icon > svg { position: absolute; left: var(--jk-space-4); top: 36px; width: 17px; height: 17px; color: var(--jk-text-muted); }

.check-row { display: flex; align-items: flex-start; gap: var(--jk-space-3); font: var(--jk-text-sm); color: var(--jk-text-muted); }
.check-row input { margin-top: 2px; width: 16px; height: 16px; accent-color: var(--jk-primary); }

/* toggle switch */
.switch { position: relative; display: inline-flex; align-items: center; gap: var(--jk-space-3); cursor: pointer; }
.switch input { position: absolute; opacity: 0; width: 0; height: 0; }
.switch__track { width: 42px; height: 24px; border-radius: var(--jk-radius-pill); background: var(--jk-border); transition: background .2s; position: relative; flex: none; }
.switch__track::after { content: ''; position: absolute; top: 3px; left: 3px; width: 18px; height: 18px; border-radius: 50%; background: var(--jk-bg-elevated); box-shadow: var(--jk-shadow-sm); transition: transform .2s; }
.switch input:checked + .switch__track { background: var(--jk-primary); }
.switch input:checked + .switch__track::after { transform: translateX(18px); }
.switch input:focus-visible + .switch__track { box-shadow: var(--jk-focus-ring); }

/* segmented control */
.segment { display: inline-flex; padding: var(--jk-space-1); background: var(--jk-bg-subtle); border-radius: var(--jk-radius-pill); border: 1px solid var(--jk-border); }
.segment__button { border: none; background: transparent; height: 34px; padding: 0 var(--jk-space-5); border-radius: var(--jk-radius-pill); font: var(--jk-text-sm); font-weight: 600; color: var(--jk-text-muted); transition: all .15s; }
.segment__button--on { background: var(--jk-bg-elevated); color: var(--jk-text); box-shadow: var(--jk-shadow-sm); }

/* labelled divider */
.or-line { display: flex; align-items: center; gap: var(--jk-space-4); color: var(--jk-text-muted); font: var(--jk-text-caption); }
.or-line::before, .or-line::after { content: ''; flex: 1; height: 1px; background: var(--jk-border); }

/* ============================================================
   Data table
   ============================================================ */
.table-wrap { overflow-x: auto; }
.data-table { width: 100%; border-collapse: collapse; font: var(--jk-text-body); }
.data-table th {
  text-align: left; font: var(--jk-text-label); letter-spacing: .05em; text-transform: uppercase;
  color: var(--jk-text-muted); padding: var(--jk-space-3) var(--jk-space-5); border-bottom: 1px solid var(--jk-border);
  background: var(--jk-bg-subtle); white-space: nowrap;
}
.data-table td { padding: var(--jk-space-4) var(--jk-space-5); border-bottom: 1px solid var(--jk-border); vertical-align: middle; }
.data-table tr:last-child td { border-bottom: none; }
.data-table tbody tr { transition: background .12s; }
.data-table tbody tr:hover { background: var(--jk-bg-subtle); }
.data-table__strong { font-weight: 600; color: var(--jk-text); }
.data-table__actions { display: flex; gap: var(--jk-space-2); justify-content: flex-end; }

.icon-button { width: 32px; height: 32px; border-radius: var(--jk-radius); border: 1px solid var(--jk-border); background: var(--jk-bg-elevated); display: grid; place-items: center; color: var(--jk-text-muted); transition: all .15s; }
.icon-button:hover { color: var(--jk-text); border-color: var(--jk-text-muted); background: var(--jk-bg-subtle); }
.icon-button svg { width: 16px; height: 16px; }

/* ============================================================
   License key block (monospace, copy/reveal/reissue)
   ============================================================ */
.key-block {
  display: flex; align-items: center; gap: var(--jk-space-3); background: var(--jk-text); color: var(--jk-bg-elevated);
  border-radius: var(--jk-radius); padding: var(--jk-space-3) var(--jk-space-4); font-family: var(--jk-mono); font-size: 13.5px;
}
[data-theme="dark"] .key-block { background: #060B16; border: 1px solid var(--jk-border); color: #CBD5E1; }
.key-block__key { flex: 1; letter-spacing: .04em; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.key-block__key--masked { letter-spacing: .18em; }
.key-block__actions { display: inline-flex; align-items: center; gap: var(--jk-space-2); }
.key-block__button {
  background: color-mix(in srgb, var(--jk-bg) 14%, transparent); border: 1px solid color-mix(in srgb, var(--jk-bg) 18%, transparent);
  color: var(--jk-bg-subtle); height: 30px; padding: 0 var(--jk-space-3); border-radius: var(--jk-radius-sm);
  font: var(--jk-text-caption); font-weight: 500; font-family: var(--jk-font); display: inline-flex; align-items: center; gap: var(--jk-space-1); transition: background .15s;
}
.key-block__button:hover { background: color-mix(in srgb, var(--jk-bg) 26%, transparent); color: var(--jk-bg); }
.key-block__button svg { width: 14px; height: 14px; }

/* ============================================================
   Meter / progress
   ============================================================ */
.meter { height: 9px; border-radius: var(--jk-radius-pill); background: var(--jk-bg-subtle); overflow: hidden; border: 1px solid var(--jk-border); }
.meter__fill { display: block; height: 100%; border-radius: var(--jk-radius-pill); background: var(--jk-primary); }
.meter--warning .meter__fill { background: var(--jk-warning); }
.meter--danger .meter__fill { background: var(--jk-danger); }

/* ============================================================
   Stat tile
   ============================================================ */
.stat { display: flex; flex-direction: column; gap: var(--jk-space-2); }
.stat__label { font: var(--jk-text-sm); font-weight: 600; color: var(--jk-text-muted); display: flex; align-items: center; gap: var(--jk-space-2); }
.stat__label svg { width: 16px; height: 16px; color: var(--jk-primary); }
.stat__value { font: var(--jk-text-display); font-size: 32px; letter-spacing: var(--jk-text-tracking-tight); }
.stat__sub { font: var(--jk-text-caption); color: var(--jk-text-muted); }

/* ============================================================
   Site header (public top nav) — project block
   ============================================================ */
.site-header { position: sticky; top: 0; z-index: var(--jk-z-sticky); background: color-mix(in srgb, var(--jk-bg) 82%, transparent); backdrop-filter: blur(12px); border-bottom: 1px solid var(--jk-border); }
.site-header__inner { max-width: var(--jk-content-max); margin: 0 auto; padding: 0 var(--jk-space-6); height: 64px; display: flex; align-items: center; gap: var(--jk-space-8); }
.site-header__nav { display: flex; align-items: center; gap: var(--jk-space-6); font: var(--jk-text-body); font-weight: 500; color: var(--jk-text); }
.site-header__nav a { display: inline-flex; align-items: center; gap: var(--jk-space-1); transition: color .15s; }
.site-header__nav a:hover { color: var(--jk-primary); }
.site-header__right { margin-left: auto; display: flex; align-items: center; gap: var(--jk-space-3); }

/* logo lockup */
.brand-logo { display: inline-flex; align-items: center; gap: var(--jk-space-2); font: var(--jk-text-h4); font-weight: 800; letter-spacing: var(--jk-text-tracking-tight); color: var(--jk-text); }
.brand-logo__glyph { width: 30px; height: 30px; border-radius: var(--jk-radius); background: var(--jk-primary); display: grid; place-items: center; box-shadow: var(--jk-shadow-brand); }
.brand-logo__glyph svg { width: 17px; height: 17px; color: var(--jk-on-primary); }

/* dark-mode toggle */
.theme-toggle { width: 38px; height: 38px; border-radius: var(--jk-radius); border: 1px solid var(--jk-border); background: var(--jk-bg-elevated); display: grid; place-items: center; color: var(--jk-text-muted); }
.theme-toggle:hover { color: var(--jk-text); border-color: var(--jk-text-muted); }
.theme-toggle svg { width: 18px; height: 18px; }
.theme-toggle__moon { display: none; }
[data-theme="dark"] .theme-toggle__sun { display: none; }
[data-theme="dark"] .theme-toggle__moon { display: block; }

/* ============================================================
   App shell (jk-shell topbar + portal sidebar + content)
   ============================================================ */
/* jk-shell topbar (reused component — markup per components.md §4.5) */
.jk-shell { position: sticky; top: 0; z-index: var(--jk-z-sticky); height: 64px; background: color-mix(in srgb, var(--jk-bg) 85%, transparent); backdrop-filter: blur(10px); border-bottom: 1px solid var(--jk-border); display: flex; align-items: center; padding: 0 var(--jk-space-6); }
.jk-shell__brand { display: inline-flex; }
.jk-shell__menu { margin-left: auto; display: flex; align-items: center; gap: var(--jk-space-3); }
.jk-shell__user { display: flex; align-items: center; gap: var(--jk-space-3); padding: var(--jk-space-1); border-radius: var(--jk-radius-pill); border: 1px solid var(--jk-border); background: var(--jk-bg-elevated); cursor: pointer; }
.jk-shell__who { padding-right: var(--jk-space-2); line-height: 1.15; text-align: right; }
.jk-shell__who b { font: var(--jk-text-sm); font-weight: 600; display: block; }
.jk-shell__who span { font: var(--jk-text-caption); color: var(--jk-text-muted); }

.avatar { width: 34px; height: 34px; border-radius: 50%; background: var(--jk-primary); color: var(--jk-on-primary); font: var(--jk-text-sm); font-weight: 700; display: grid; place-items: center; }
.avatar--sm { width: 28px; height: 28px; font-size: 11px; }

/* portal grid */
.portal { display: grid; grid-template-columns: var(--jk-sidebar-width) 1fr; min-height: calc(100vh - 64px); background: var(--jk-bg-subtle); }
.portal-nav { background: var(--jk-bg-elevated); border-right: 1px solid var(--jk-border); padding: var(--jk-space-4) var(--jk-space-3); position: sticky; top: 64px; height: calc(100vh - 64px); overflow-y: auto; display: flex; flex-direction: column; }
.portal-nav__group { font: var(--jk-text-label); letter-spacing: .06em; text-transform: uppercase; color: var(--jk-text-muted); padding: var(--jk-space-4) var(--jk-space-3) var(--jk-space-2); }
.portal-nav__item { display: flex; align-items: center; gap: var(--jk-space-3); padding: var(--jk-space-2) var(--jk-space-3); border-radius: var(--jk-radius); font: var(--jk-text-body); font-weight: 500; color: var(--jk-text); margin-bottom: 2px; transition: all .14s; }
.portal-nav__item svg { width: 18px; height: 18px; color: var(--jk-text-muted); flex: none; }
.portal-nav__item:hover { background: var(--jk-bg-subtle); }
.portal-nav__item--active { background: var(--jk-primary-soft); color: var(--jk-primary); font-weight: 600; }
.portal-nav__item--active svg { color: var(--jk-primary); }
.portal-nav__count { margin-left: auto; font: var(--jk-text-caption); font-weight: 600; background: var(--jk-bg-subtle); color: var(--jk-text-muted); padding: 1px var(--jk-space-2); border-radius: var(--jk-radius-pill); }
.portal-nav__item--active .portal-nav__count { background: var(--jk-bg-elevated); color: var(--jk-primary); }
.portal-nav__foot { margin-top: auto; padding-top: var(--jk-space-4); border-top: 1px solid var(--jk-border); }

.portal-main { min-width: 0; padding: var(--jk-space-8); }
.portal-main__inner { max-width: var(--jk-content-max); margin: 0 auto; }

.page-head { margin-bottom: var(--jk-space-6); }
.page-head__title { font: var(--jk-text-h1); letter-spacing: var(--jk-text-tracking-tight); }
.page-head__sub { color: var(--jk-text-muted); margin-top: var(--jk-space-1); }
.crumbs { display: flex; align-items: center; gap: var(--jk-space-2); font: var(--jk-text-sm); color: var(--jk-text-muted); margin-bottom: var(--jk-space-3); }
.crumbs a:hover { color: var(--jk-primary); }
.crumbs svg { width: 14px; height: 14px; }

/* ============================================================
   Footer (§6 — JK Networks business info)
   ============================================================ */
.site-footer { background: var(--jk-footer-bg); color: var(--jk-footer-text); padding: var(--jk-space-16) 0 var(--jk-space-10); border-top: 1px solid var(--jk-footer-line); }
.site-footer__cols { display: grid; grid-template-columns: 1.6fr repeat(3, 1fr); gap: var(--jk-space-10); }
.site-footer__col h5 { color: var(--jk-footer-heading); font: var(--jk-text-sm); font-weight: 600; margin: 0 0 var(--jk-space-4); }
.site-footer__col ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: var(--jk-space-3); }
.site-footer a { font: var(--jk-text-body); color: var(--jk-footer-text); transition: color .15s; }
.site-footer a:hover { color: var(--jk-footer-heading); }
.site-footer .brand-logo { color: var(--jk-footer-heading); }
.site-footer__blurb { font: var(--jk-text-body); margin: var(--jk-space-4) 0 var(--jk-space-5); max-width: 290px; line-height: 1.6; }
.site-footer__switch { display: flex; gap: var(--jk-space-2); }
.locale-pick { background: var(--jk-footer-control-bg); border: 1px solid var(--jk-footer-control-border); color: var(--jk-footer-text); height: 34px; border-radius: var(--jk-radius); padding: 0 var(--jk-space-3); font: var(--jk-text-sm); font-family: var(--jk-font); }
.site-footer__bottom { margin-top: var(--jk-space-12); padding-top: var(--jk-space-6); border-top: 1px solid var(--jk-footer-line); }
.site-footer__biz { font: var(--jk-text-caption); line-height: 1.9; color: var(--jk-footer-muted); }
.site-footer__copy { font: var(--jk-text-caption); margin-top: var(--jk-space-3); color: var(--jk-footer-text); }

/* ============================================================
   Hero mesh / decorative (token-derived only)
   ============================================================ */
.mesh {
  position: absolute; inset: 0; overflow: hidden; z-index: -1;
  background:
    radial-gradient(58% 55% at 18% 12%, color-mix(in srgb, var(--jk-primary) 20%, transparent), transparent 60%),
    radial-gradient(46% 50% at 86% 8%, color-mix(in srgb, var(--jk-primary) 14%, transparent), transparent 60%),
    radial-gradient(50% 60% at 62% 100%, color-mix(in srgb, var(--jk-primary) 10%, transparent), transparent 60%);
}
.mesh-grid {
  position: absolute; inset: 0; z-index: -1; opacity: .6;
  background-image: linear-gradient(var(--jk-border) 1px, transparent 1px), linear-gradient(90deg, var(--jk-border) 1px, transparent 1px);
  background-size: 56px 56px;
  -webkit-mask-image: radial-gradient(70% 60% at 50% 28%, #000, transparent 75%);
          mask-image: radial-gradient(70% 60% at 50% 28%, #000, transparent 75%);
}

.trust-strip { display: flex; align-items: center; gap: var(--jk-space-6); flex-wrap: wrap; color: var(--jk-text-muted); font: var(--jk-text-body); }
.trust-strip__stars { color: var(--jk-warning); letter-spacing: 2px; }

.feature-icon { width: 40px; height: 40px; border-radius: var(--jk-radius); background: var(--jk-primary-soft); color: var(--jk-primary); display: grid; place-items: center; }
.feature-icon svg { width: 20px; height: 20px; }

/* placeholder image */
.placeholder {
  border-radius: var(--jk-radius-lg); border: 1px solid var(--jk-border);
  background: repeating-linear-gradient(135deg, var(--jk-bg-subtle) 0 12px, var(--jk-bg) 12px 24px);
  display: grid; place-items: center; color: var(--jk-text-muted);
  font-family: var(--jk-mono); font-size: 12px; letter-spacing: .03em; text-align: center; padding: var(--jk-space-4);
}

/* accordion */
.accordion__item { border-bottom: 1px solid var(--jk-border); }
.accordion__q { display: flex; align-items: center; justify-content: space-between; gap: var(--jk-space-4); padding: var(--jk-space-5) 0; font: var(--jk-text-body-lg); font-weight: 600; cursor: pointer; width: 100%; background: none; border: none; color: var(--jk-text); text-align: left; }
.accordion__q svg { width: 18px; height: 18px; color: var(--jk-text-muted); transition: transform .2s; flex: none; }
.accordion__item--open .accordion__q svg { transform: rotate(45deg); }
.accordion__a { max-height: 0; overflow: hidden; transition: max-height .25s ease; color: var(--jk-text-muted); line-height: 1.65; }
.accordion__item--open .accordion__a { max-height: 320px; padding-bottom: var(--jk-space-5); }

/* empty state */
.empty-state { text-align: center; padding: var(--jk-space-16) var(--jk-space-6); }
.empty-state__icon { width: 56px; height: 56px; border-radius: var(--jk-radius-lg); background: var(--jk-bg-subtle); color: var(--jk-text-muted); display: grid; place-items: center; margin: 0 auto var(--jk-space-4); }
.empty-state__icon svg { width: 26px; height: 26px; }
.empty-state h3 { font: var(--jk-text-h4); margin-bottom: var(--jk-space-2); }
.empty-state p { color: var(--jk-text-muted); max-width: 360px; margin: 0 auto var(--jk-space-5); }

/* ============================================================
   jk-modal / jk-toast (reused components — markup per components.md)
   ============================================================ */
.jk-modal { position: fixed; inset: 0; background: color-mix(in srgb, var(--jk-text) 50%, transparent); backdrop-filter: blur(3px); display: none; place-items: center; z-index: var(--jk-z-modal); padding: var(--jk-space-6); }
.jk-modal--open { display: grid; }
.jk-modal__panel { background: var(--jk-bg-elevated); border: 1px solid var(--jk-border); border-radius: var(--jk-radius-lg); box-shadow: var(--jk-shadow-lg); width: 100%; max-width: 440px; overflow: hidden; }
.jk-modal__head { padding: var(--jk-space-6) var(--jk-space-6) 0; }
.jk-modal__head h3 { font: var(--jk-text-h3); }
.jk-modal__body { padding: var(--jk-space-3) var(--jk-space-6) 0; color: var(--jk-text-muted); line-height: 1.6; }
.jk-modal__foot { padding: var(--jk-space-6); display: flex; gap: var(--jk-space-3); justify-content: flex-end; }

.jk-toast { position: fixed; top: var(--jk-space-6); right: var(--jk-space-6); z-index: var(--jk-z-toast); display: flex; flex-direction: column; gap: var(--jk-space-3); }
.jk-toast__item { display: flex; align-items: center; gap: var(--jk-space-3); background: var(--jk-text); color: var(--jk-bg); padding: var(--jk-space-3) var(--jk-space-4); border-radius: var(--jk-radius); box-shadow: var(--jk-shadow-lg); font: var(--jk-text-body); font-weight: 500; max-width: 340px; animation: jk-toast-in .25s ease; }
.jk-toast__icon { width: 20px; height: 20px; border-radius: 50%; display: grid; place-items: center; flex: none; color: var(--jk-bg); }
.jk-toast__item--success .jk-toast__icon { background: var(--jk-success); }
.jk-toast__item--error .jk-toast__icon { background: var(--jk-danger); }
.jk-toast__item--info .jk-toast__icon { background: var(--jk-primary); }
.jk-toast__icon svg { width: 13px; height: 13px; }
@keyframes jk-toast-in { from { opacity: 0; transform: translateX(16px); } }

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 1024px) {
  .grid--4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 900px) {
  :root { --jk-text-display: 800 32px/1.12 var(--jk-font); --jk-text-h1: 700 26px/1.2 var(--jk-font); }
  .section { padding: var(--jk-space-16) 0; }
  .site-footer__cols { grid-template-columns: 1fr 1fr; gap: var(--jk-space-8); }
  .grid--3 { grid-template-columns: 1fr; }
  .portal { grid-template-columns: 1fr; }
  .portal-nav { display: none; }
  .portal-main { padding: var(--jk-space-5); }
}
@media (max-width: 640px) {
  .container { padding: 0 var(--jk-space-4); }
  .site-header__nav { display: none; }
  .grid--2, .grid--4 { grid-template-columns: 1fr; }
  .site-footer__cols { grid-template-columns: 1fr; }
  .hide-sm { display: none !important; }
}
