/* PULS — capa específica de la app, sobre los tokens de noktir-theme.css */

* { box-sizing: border-box; }

.wrap {
  max-width: 560px;
  margin: 0 auto;
  padding: 48px 24px 80px;
}

header { margin-bottom: 40px; }

.nk-sigil svg { display: block; width: 22px; height: 22px; }

h1.nk-wordmark {
  font-weight: 700;
  font-size: 28px;
  margin: 0;
}

.subtitle {
  color: var(--nk-text-3);
  text-transform: uppercase;
  letter-spacing: 2px;
  font-size: 12px;
  margin: 6px 0 16px;
}

.top-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.ranking-link {
  color: var(--nk-text);
  text-decoration: none;
  font-size: 13px;
  border-bottom: 1px solid var(--nk-line);
  padding-bottom: 2px;
}

.field { margin-bottom: 24px; }

label {
  display: block;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--nk-text-3);
  margin-bottom: 8px;
}

select, input[type="text"], input[type="number"] {
  width: 100%;
  background: var(--nk-surface);
  border: 1px solid var(--nk-line);
  color: var(--nk-text);
  padding: 12px 14px;
  font-size: 15px;
  border-radius: 4px;
}

.radio-row {
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
}

.radio-row label, .checkbox-row label {
  display: flex;
  align-items: center;
  gap: 8px;
  text-transform: none;
  letter-spacing: 0;
  font-size: 14px;
  color: var(--nk-text);
  margin-bottom: 8px;
}

fieldset {
  border: 1px solid var(--nk-line);
  border-radius: 6px;
  padding: 16px;
  margin-bottom: 24px;
}

legend {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--nk-text-3);
  padding: 0 6px;
}

.nivel-sub {
  margin-top: 10px;
  padding-left: 16px;
  border-left: 2px solid var(--nk-line);
}

button:not(.nk-theme-toggle):not(.toggle-row button) {
  width: 100%;
  background: var(--nk-logo);
  color: var(--nk-bg);
  border: none;
  padding: 14px;
  font-size: 14px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 2px;
  border-radius: 4px;
  cursor: pointer;
}

button:disabled { opacity: 0.4; cursor: not-allowed; }

#status-msg {
  margin-top: 14px;
  font-size: 13px;
  color: var(--nk-text-3);
  min-height: 18px;
}

#status-msg.ok { color: var(--nk-text); font-weight: 700; }
#status-msg.error { color: var(--nk-text); text-decoration: underline; }
