/* Web-app specific styling on top of the shared dark-industrial theme. */
.webapp-tag {
  font-size: 0.65rem; font-weight: 600; color: var(--accent);
  border: 1px solid var(--accent); border-radius: 6px; padding: 1px 6px;
  vertical-align: middle; margin-left: 4px;
}

.linklike {
  background: none; border: none; color: var(--text-2); cursor: pointer;
  font-size: 0.9rem; padding: 0;
}
.linklike:hover { color: var(--text); }

.auth-card {
  max-width: 380px; margin: 56px auto 0; background: var(--surface);
  border: 1px solid rgba(140,148,158,0.15); border-radius: 16px; padding: 28px;
  text-align: center;
}
.auth-card h1 { font-size: 1.4rem; margin-bottom: 8px; }
.auth-card form { display: flex; flex-direction: column; gap: 10px; margin: 18px 0 10px; }
.auth-card input {
  background: var(--bg); color: var(--text); border: 1px solid rgba(140,148,158,0.3);
  border-radius: 10px; padding: 11px 13px; font-size: 0.95rem;
}
.auth-card input:focus { outline: 1px solid var(--accent); }
.divider { display: flex; align-items: center; gap: 10px; color: var(--steel); margin: 14px 0; font-size: 0.8rem; }
.divider::before, .divider::after { content: ""; flex: 1; height: 1px; background: rgba(140,148,158,0.25); }

button.primary {
  background: var(--accent); color: #16110a; font-weight: 700; border: none;
  border-radius: 10px; padding: 11px; font-size: 0.95rem; cursor: pointer;
}
button.secondary {
  background: var(--surface-elevated); color: var(--text); border: 1px solid rgba(140,148,158,0.3);
  border-radius: 10px; padding: 10px 14px; font-size: 0.9rem; cursor: pointer; width: 100%;
}
button.secondary.small { width: auto; padding: 7px 12px; font-size: 0.82rem; }
button.danger {
  background: none; color: var(--error); border: 1px solid var(--error);
  border-radius: 10px; padding: 9px 14px; font-size: 0.9rem; cursor: pointer;
}
button:disabled { opacity: 0.5; cursor: default; }

.msg { margin-top: 12px; font-size: 0.88rem; color: var(--error); }
.msg.ok { color: var(--business); }
.muted { color: var(--text-2); font-size: 0.92rem; }
.footnote { margin-top: 28px; font-size: 0.85rem; }

.dash-head { display: flex; align-items: center; flex-wrap: wrap; gap: 12px; margin-top: 32px; }
.dash-head h1 { font-size: 1.5rem; margin-right: auto; }
.dash-actions { display: flex; gap: 8px; align-items: center; }
.dash-actions select {
  background: var(--surface-elevated); color: var(--text);
  border: 1px solid rgba(140,148,158,0.3); border-radius: 8px; padding: 7px 10px;
}

.cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 12px; margin: 20px 0; }
.card {
  background: var(--surface); border: 1px solid rgba(140,148,158,0.15);
  border-radius: 12px; padding: 14px 16px;
}
.card .label { color: var(--steel); font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.05em; }
.card .value { font-size: 1.45rem; font-weight: 700; font-variant-numeric: tabular-nums; margin-top: 2px; }
.card .value.amber { color: var(--accent); }

.tabs { display: flex; gap: 6px; border-bottom: 1px solid rgba(140,148,158,0.2); margin: 8px 0 0; }
.tab {
  background: none; border: none; color: var(--text-2); padding: 10px 14px;
  font-size: 0.95rem; cursor: pointer; border-bottom: 2px solid transparent;
}
.tab.active { color: var(--accent); border-bottom-color: var(--accent); font-weight: 600; }

table.data { width: 100%; border-collapse: collapse; margin-top: 6px; font-size: 0.9rem; }
table.data th {
  text-align: left; color: var(--steel); font-size: 0.75rem; text-transform: uppercase;
  letter-spacing: 0.05em; padding: 10px 10px 6px; border-bottom: 1px solid rgba(140,148,158,0.2);
}
table.data td { padding: 9px 10px; border-bottom: 1px solid rgba(140,148,158,0.1); color: var(--text-2); }
table.data td.num { text-align: right; font-variant-numeric: tabular-nums; color: var(--text); }
table.data tr.month-row td {
  color: var(--text); font-weight: 600; background: var(--surface);
  border-bottom: 1px solid rgba(140,148,158,0.2);
}
.badge { display: inline-block; border-radius: 6px; padding: 1px 8px; font-size: 0.75rem; font-weight: 600; }
.badge.business { background: rgba(77,184,115,0.15); color: var(--business); }
.badge.personal { background: rgba(140,148,158,0.18); color: var(--steel); }
.badge.unclassified { background: rgba(200,120,30,0.15); color: var(--accent); }

.danger-zone { margin-top: 40px; border-top: 1px solid rgba(140,148,158,0.15); padding-top: 16px; }
.danger-zone summary { color: var(--steel); cursor: pointer; font-size: 0.9rem; }
.danger-zone p { margin: 12px 0; }

.empty { text-align: center; color: var(--steel); padding: 36px 0; }
