/* Portal-spezifische Styles. Baut auf design-tokens.css + components.css auf. */

* { box-sizing: border-box; }
html, body { height: 100%; }
body {
  margin: 0;
  font-family: var(--font-body);
  color: var(--color-text);
  background: var(--color-surface, #f5f5f7);
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

/* ---------- Auth-Seiten (zentrierte Card) ---------- */
body.auth-page {
  background:
    radial-gradient(circle at 20% 20%, rgba(206, 33, 40, 0.10), transparent 60%),
    radial-gradient(circle at 80% 80%, rgba(206, 33, 40, 0.06), transparent 55%),
    var(--color-surface, #f5f5f7);
}
.auth-main { flex: 1; display: flex; align-items: center; justify-content: center; padding: 24px; }
.auth-card {
  width: 100%; max-width: 420px;
  background: var(--color-bg, #fff);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow: 0 8px 32px rgba(0,0,0,0.08);
  padding: 36px 32px;
}
.auth-card-wide { max-width: 560px; }
.auth-brand { text-align: center; margin-bottom: 24px; }
.auth-brand-mark { font-size: 26px; font-weight: 600; color: var(--color-text-strong); letter-spacing: -0.5px; }
.auth-brand-mark i { color: var(--color-accent); font-style: italic; font-weight: 700; }
.auth-brand-sub { margin-top: 6px; font-size: 13px; text-transform: uppercase; letter-spacing: 0.4px; color: var(--color-text-light); }
.auth-field { margin-bottom: 16px; }
.auth-field label { display: block; font-size: 13px; font-weight: 600; margin-bottom: 5px; color: var(--color-text); }
.auth-field input {
  width: 100%; padding: 11px 12px; font: inherit;
  border: 1px solid var(--color-border); border-radius: var(--radius-sm);
  background: #fff; color: var(--color-text-strong);
}
.auth-field input:focus { outline: none; border-color: var(--color-accent); box-shadow: 0 0 0 3px rgba(206,33,40,0.15); }
.auth-error { background: #fdecec; border: 1px solid var(--color-danger); color: var(--color-danger); padding: 10px 12px; border-radius: var(--radius-sm); font-size: 14px; margin-bottom: 16px; }
.auth-inline-error { color: var(--color-danger); font-size: 13px; margin-top: 8px; }
.auth-hint { font-size: 14px; line-height: 1.55; margin: 0 0 20px; }
.auth-foot { margin-top: 20px; font-size: 13px; text-align: center; color: var(--color-text-light); }
.auth-foot a { color: var(--color-accent); }
.auth-section { margin-top: 16px; }
.auth-or { text-align: center; margin: 16px 0; color: var(--color-text-light); font-size: 13px; position: relative; }

/* ---------- Eingeloggte Chrome ---------- */
.portal-topbar {
  display: flex; align-items: center; justify-content: space-between;
  background: var(--color-bg, #fff); border-bottom: 1px solid var(--color-border);
  padding: 10px 24px; gap: 16px;
}
.portal-brand { display: flex; align-items: center; gap: 10px; text-decoration: none; color: var(--color-text-strong); font-weight: 600; }
.portal-logo { height: 28px; width: auto; }
.portal-nav { display: flex; align-items: center; gap: 18px; }
.portal-nav a { text-decoration: none; color: var(--color-text); font-size: 14px; font-weight: 500; }
.portal-nav a:hover { color: var(--color-accent); }
.portal-logout-form { margin: 0; }
.portal-main { flex: 1; width: 100%; max-width: 920px; margin: 0 auto; padding: 28px 24px; }
.portal-footer { display: flex; justify-content: space-between; gap: 12px; padding: 16px 24px; font-size: 12px; color: var(--color-text-light); border-top: 1px solid var(--color-border); flex-wrap: wrap; }
.portal-footer i { font-style: italic; color: var(--color-accent); }
.portal-flashes { margin-bottom: 18px; display: flex; flex-direction: column; gap: 8px; }

/* ---------- Seiteninhalte ---------- */
.page-head { margin-bottom: 20px; }
.page-head h1 { font-family: var(--font-display); font-size: 26px; margin: 0 0 4px; color: var(--color-text-strong); }
.muted { color: var(--color-text-light); font-size: 14px; }
.card { background: var(--color-bg, #fff); border: 1px solid var(--color-border); border-radius: var(--radius-md); margin-bottom: 20px; overflow: hidden; }
.card-header { padding: 14px 18px; border-bottom: 1px solid var(--color-border); }
.card-header h2 { margin: 0; font-size: 16px; color: var(--color-text-strong); }
.card-content { padding: 18px; }
.card-content p { line-height: 1.55; }

.card-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 16px; margin-bottom: 22px; }
.info-card { display: block; background: var(--color-bg, #fff); border: 1px solid var(--color-border); border-left: 4px solid var(--color-accent); border-radius: var(--radius-md); padding: 18px; text-decoration: none; color: inherit; }
.info-card:hover { box-shadow: var(--shadow-md); }
.info-card-num { font-family: var(--font-display); font-size: 32px; font-weight: 700; color: var(--color-text-strong); line-height: 1; }
.info-card-label { font-size: 13px; color: var(--color-text-light); margin: 6px 0 10px; }
.info-card-cta { font-size: 13px; font-weight: 600; color: var(--color-accent); }

.inline-form { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; }
.inline-form .input { flex: 1; min-width: 220px; }
.stack-form { display: flex; flex-direction: column; gap: 12px; max-width: 380px; }
.stack-form label { font-size: 13px; font-weight: 600; display: flex; flex-direction: column; gap: 5px; }

.data-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.data-table th, .data-table td { text-align: left; padding: 10px 8px; border-bottom: 1px solid var(--color-border); }
.data-table th { font-size: 12px; text-transform: uppercase; letter-spacing: 0.3px; color: var(--color-text-light); }
.row-revoked { color: var(--color-text-light); }

.device-list { list-style: none; padding: 0; margin: 0 0 14px; }
.device-list li { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 10px 0; border-bottom: 1px solid var(--color-border); font-size: 14px; }
.device-list form { margin: 0; }

.factor-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin: 8px 0 8px; }
.factor-card { border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: 16px; }
.factor-card h3 { margin: 0 0 6px; font-size: 16px; color: var(--color-text-strong); }
.factor-card p { font-size: 13px; color: var(--color-text-light); line-height: 1.5; margin: 0 0 12px; }
.factor-list { list-style: none; padding: 0; margin: 0 0 12px; font-size: 13px; color: var(--color-success-strong, #2d8a4f); }

.totp-qr { display: flex; justify-content: center; margin: 16px 0; }
.totp-qr img { border: 1px solid var(--color-border); border-radius: var(--radius-sm); padding: 8px; background: #fff; }
.totp-steps { padding-left: 20px; line-height: 1.6; }

.recovery-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin: 18px 0; }
.recovery-code { font-family: var(--font-mono); font-size: 16px; letter-spacing: 1px; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-sm); padding: 10px; text-align: center; }

.apppw-reveal { margin: 16px 0; text-align: center; }
.apppw-value { display: inline-block; font-family: var(--font-mono); font-size: 22px; letter-spacing: 2px; background: var(--color-accent-soft, #fbe9ea); border: 1px solid var(--color-accent); color: var(--color-text-strong); border-radius: var(--radius-sm); padding: 14px 22px; }
.apppw-settings { display: grid; grid-template-columns: max-content 1fr; gap: 6px 18px; margin: 18px 0; font-size: 14px; }
.apppw-settings dt { font-weight: 600; color: var(--color-text-light); }
.apppw-settings dd { margin: 0; }

.info-card-admin { border-left-color: var(--color-text-strong); }
.stack-form select.input, .inline-form select.input { background: #fff; }
.stack-form { max-width: 520px; }
.loc-fieldset { border: 1px solid var(--color-border); border-radius: var(--radius-sm); padding: 12px 14px; }
.loc-fieldset legend { font-size: 13px; font-weight: 600; padding: 0 6px; }
.checkbox-row { display: flex; align-items: center; gap: 8px; font-weight: 400; margin: 4px 0; }
.checkbox-row input { width: auto; }

@media (max-width: 560px) {
  .factor-grid, .recovery-grid { grid-template-columns: 1fr; }
  .portal-nav { gap: 12px; }
  .portal-nav a { font-size: 13px; }
  .data-table { font-size: 13px; }
}
