/* ============================================================
   FLYTTSTÄDNING PRISKALKYL
   ============================================================ */

.flyttkalkyl {
  max-width: 780px;
  margin-inline: auto;
}

.flyttkalkyl__inner {
  padding: var(--sp-6);
  /*border: 1px solid var(--color-border, rgba(255,255,255,0.12));*/
  border: 1px solid var(--clr-border, rgba(255,255,255,0.12));
  border-radius: var(--radius-lg, 20px);
  /*background: var(--color-surface, rgba(255,255,255,0.03));*/
  background: var(--clr-bg-card);
  box-shadow: 0 10px 30px rgba(0,0,0,0.06);
}

.flyttkalkyl__intro,
.flyttkalkyl__note {
  margin: 0;
  line-height: 1.7;
}

.flyttkalkyl__intro {
  margin-bottom: var(--sp-5);
}

.flyttkalkyl__controls {
  margin-bottom: var(--sp-5);
}

.flyttkalkyl__controls label {
  display: block;
  margin-bottom: 0.65rem;
  font-weight: 600;
}

.flyttkalkyl__input-group {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  flex-wrap: nowrap;
}

.flyttkalkyl__btn {
  width: 46px;
  height: 46px;
  border: 1px solid var(--clr-border, rgba(255,255,255,0.15));
  border-radius: 12px;
  background: transparent;
  color: inherit;
  font-size: 1.5rem;
  line-height: 1;
  cursor: pointer;
  transition: transform 0.15s ease, background-color 0.15s ease, border-color 0.15s ease;
}

.flyttkalkyl__btn:hover,
.flyttkalkyl__btn:focus-visible {
  background: rgba(255,255,255,0.06);
  border-color: rgba(255,255,255,0.24);
  transform: translateY(-1px);
}

.flyttkalkyl__input-group input {
  width: 120px;
  height: 46px;
  padding: 0 0.75rem;
  border: 1px solid var(--clr-border, rgba(255,255,255,0.15));
  border-radius: 12px;
  background: transparent;
  color: inherit;
  text-align: center;
  font-size: 1rem;
}

.flyttkalkyl__input-group input:focus-visible {
  outline: 2px solid currentColor;
  outline-offset: 2px;
}

.flyttkalkyl__result {
  margin-bottom: var(--sp-5);
  padding: 1rem 1.1rem;
  border: 1px solid var(--clr-border,  rgba(255,255,255,0.15));
  border-radius: 14px;
  background: rgba(255,255,255,0.05);
  /*border: 1px solid rgba(255,255,255,0.08);*/
}

.flyttkalkyl__result-label {
  margin: 0 0 0.35rem;
  font-size: 0.95rem;
  opacity: 0.85;
}

.flyttkalkyl__result-value {
  margin: 0;
  font-size: clamp(1.55rem, 2.5vw, 2rem);
  font-weight: 700;
  line-height: 1.2;
}

.flyttkalkyl__note {
  font-size: 0.98rem;
}

.flyttkalkyl__actions {
  margin-top: var(--sp-5);
}

.flyttkalkyl__microtrust {
  margin: 0.5rem 0;
  font-size: 0.85rem;
  color: #666;
}

.flyttkalkyl__cta-note {
  margin: 0.4rem 0 0;
  font-size: 0.85rem;
  color: #666;
}

.flyttkalkyl__qualifier {
  margin: 0.75rem 0 0.5rem;
  font-size: 0.95rem;
  font-weight: 500;
  line-height: 1.6;
}

@media (max-width: 640px) {
  .flyttkalkyl__inner {
    padding: 1rem;
  }

  .flyttkalkyl__input-group {
    gap: 0.5rem;
  }

  .flyttkalkyl__btn {
    width: 44px;
    height: 44px;
  }

  .flyttkalkyl__input-group input {
    width: 96px;
    height: 44px;
  }
}

/* ============================================================
   STORSTÄDNING PRISKALKYL
   ============================================================ */

.storstadkalkyl {
  max-width: 780px;
  margin-inline: auto;
}

.storstadkalkyl__inner {
  padding: var(--sp-6);
  border: 1px solid var(--clr-border, rgba(255,255,255,0.12));
  border-radius: var(--radius-lg, 20px);
  background: var(--clr-bg-card);
  box-shadow: 0 10px 30px rgba(0,0,0,0.06);
}

.storstadkalkyl__intro,
.storstadkalkyl__note {
  margin: 0;
  line-height: 1.7;
}

.storstadkalkyl__intro {
  margin-bottom: var(--sp-5);
}

.storstadkalkyl__controls {
  margin-bottom: var(--sp-5);
}

.storstadkalkyl__controls label {
  display: block;
  margin-bottom: 0.65rem;
  font-weight: 600;
}

.storstadkalkyl__input-group {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  flex-wrap: nowrap;
}

.storstadkalkyl__btn {
  width: 46px;
  height: 46px;
  border: 1px solid var(--clr-border, rgba(255,255,255,0.15));
  border-radius: 12px;
  background: transparent;
  color: inherit;
  font-size: 1.5rem;
  line-height: 1;
  cursor: pointer;
  transition: transform 0.15s ease, background-color 0.15s ease, border-color 0.15s ease;
}

.storstadkalkyl__btn:hover,
.storstadkalkyl__btn:focus-visible {
  background: rgba(255,255,255,0.06);
  border-color: rgba(255,255,255,0.24);
  transform: translateY(-1px);
}

.storstadkalkyl__input-group input {
  width: 120px;
  height: 46px;
  padding: 0 0.75rem;
  border: 1px solid var(--clr-border, rgba(255,255,255,0.15));
  border-radius: 12px;
  background: transparent;
  color: inherit;
  text-align: center;
  font-size: 1rem;
}

.storstadkalkyl__input-group input:focus-visible {
  outline: 2px solid currentColor;
  outline-offset: 2px;
}

.storstadkalkyl__options {
  margin-bottom: var(--sp-5);
}

.storstadkalkyl__checkbox {
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  cursor: pointer;
  line-height: 1.5;
}

.storstadkalkyl__checkbox input {
  width: 18px;
  height: 18px;
  accent-color: currentColor;
}

.storstadkalkyl__result {
  margin-bottom: var(--sp-5);
  padding: 1rem 1.1rem;
  border-radius: 14px;
  background: rgba(255,255,255,0.05);
  /*border: 1px solid rgba(255,255,255,0.08);*/
  border: 1px solid var(--clr-border,  rgba(255,255,255,0.15));
}

.storstadkalkyl__result-label {
  margin: 0 0 0.35rem;
  font-size: 0.95rem;
  opacity: 0.85;
}

.storstadkalkyl__result-value {
  margin: 0;
  font-size: clamp(1.55rem, 2.5vw, 2rem);
  font-weight: 700;
  line-height: 1.2;
}

.storstadkalkyl__note {
  font-size: 0.98rem;
}

.storstadkalkyl__actions {
  margin-top: var(--sp-5);
}

.storstadkalkyl__microtrust {
  margin: 0.5rem 0;
  font-size: 0.85rem;
  color: #666;
}

.storstadkalkyl__cta-note {
  margin: 0.4rem 0 0;
  font-size: 0.85rem;
  color: #666;
}

@media (max-width: 640px) {
  .storstadkalkyl__inner {
    padding: 1rem;
  }

  .storstadkalkyl__input-group {
    gap: 0.5rem;
  }

  .storstadkalkyl__btn {
    width: 44px;
    height: 44px;
  }

  .storstadkalkyl__input-group input {
    width: 96px;
    height: 44px;
  }
}

/* ============================================================
   VISNINGSSTÄDNING PRISKALKYL
   ============================================================ */

.visningskalkyl {
  max-width: 780px;
  margin-inline: auto;
}

.visningskalkyl__inner {
  padding: var(--sp-6);
  border: 1px solid var(--clr-border, rgba(255,255,255,0.12));
  border-radius: var(--radius-lg, 20px);
  background: var(--clr-bg-card);
  box-shadow: 0 10px 30px rgba(0,0,0,0.06);
}

.visningskalkyl__intro,
.visningskalkyl__note {
  margin: 0;
  line-height: 1.7;
}

.visningskalkyl__intro {
  margin-bottom: var(--sp-5);
}

.visningskalkyl__controls {
  margin-bottom: var(--sp-5);
}

.visningskalkyl__controls label {
  display: block;
  margin-bottom: 0.65rem;
  font-weight: 600;
}

.visningskalkyl__input-group {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  flex-wrap: nowrap;
}

.visningskalkyl__btn {
  width: 46px;
  height: 46px;
  border: 1px solid var(--clr-border, rgba(255,255,255,0.15));
  border-radius: 12px;
  background: transparent;
  color: inherit;
  font-size: 1.5rem;
  line-height: 1;
  cursor: pointer;
  transition: transform 0.15s ease, background-color 0.15s ease, border-color 0.15s ease;
}

.visningskalkyl__btn:hover,
.visningskalkyl__btn:focus-visible {
  background: rgba(255,255,255,0.06);
  border-color: rgba(255,255,255,0.24);
  transform: translateY(-1px);
}

.visningskalkyl__input-group input {
  width: 120px;
  height: 46px;
  padding: 0 0.75rem;
  border: 1px solid var(--clr-border, rgba(255,255,255,0.15));
  border-radius: 12px;
  background: transparent;
  color: inherit;
  text-align: center;
  font-size: 1rem;
}

.visningskalkyl__input-group input:focus-visible {
  outline: 2px solid currentColor;
  outline-offset: 2px;
}

.visningskalkyl__result {
  margin-bottom: var(--sp-5);
  padding: 1rem 1.1rem;
  border: 1px solid var(--clr-border,  rgba(255,255,255,0.15));
  border-radius: 14px;
  background: rgba(255,255,255,0.05);
  /*border: 1px solid rgba(255,255,255,0.08);*/
}

.visningskalkyl__result-label {
  margin: 0 0 0.35rem;
  font-size: 0.95rem;
  opacity: 0.85;
}

.visningskalkyl__result-value {
  margin: 0;
  font-size: clamp(1.55rem, 2.5vw, 2rem);
  font-weight: 700;
  line-height: 1.2;
}

.visningskalkyl__note {
  font-size: 0.98rem;
}

.visningskalkyl__actions {
  margin-top: var(--sp-5);
}

.visningskalkyl__microtrust {
  margin: 0.5rem 0;
  font-size: 0.85rem;
  color: #666;
}

.visningskalkyl__cta-note {
  margin: 0.4rem 0 0;
  font-size: 0.85rem;
  color: #666;
}

@media (max-width: 640px) {
  .visningskalkyl__inner {
    padding: 1rem;
  }

  .visningskalkyl__input-group {
    gap: 0.5rem;
  }

  .visningskalkyl__btn {
    width: 44px;
    height: 44px;
  }

  .visningskalkyl__input-group input {
    width: 96px;
    height: 44px;
  }
}

/* ============================================================
   HEMSTÄDNING PRISKALKYL
   ============================================================ */

.hemkalkyl {
  max-width: 780px;
  margin-inline: auto;
}

.hemkalkyl__inner {
  padding: var(--sp-6);
  border: 1px solid var(--clr-border, rgba(255,255,255,0.12));
  border-radius: var(--radius-lg, 20px);
  background: var(--clr-bg-card);
  box-shadow: 0 10px 30px rgba(0,0,0,0.06);
}

.hemkalkyl__intro,
.hemkalkyl__note {
  margin: 0;
  line-height: 1.7;
}

.hemkalkyl__intro {
  margin-bottom: var(--sp-5);
}

.hemkalkyl__controls {
  display: grid;
  gap: var(--sp-4);
  margin-bottom: var(--sp-5);
}

.hemkalkyl__field label {
  display: block;
  margin-bottom: 0.65rem;
  font-weight: 600;
}

.hemkalkyl__field select {
  cursor: pointer;
  width: 100%;
  min-height: 46px;
  padding: 0 0.9rem;
  border: 1px solid var(--clr-border, rgba(255,255,255,0.12));
  /*border: 1px solid var(--color-border, rgba(255,255,255,0.15));*/
  
  border-radius: 12px;
  background: transparent;
  background-color: var(--clr-bg-card);
  color: inherit;
  font-size: 1rem;
}

.hemkalkyl__field select:focus-visible {
  outline: 2px solid currentColor;
  outline-offset: 2px;
}

.hemkalkyl__result {
  margin-bottom: var(--sp-5);
  padding: 1rem 1.1rem;
  border-radius: 14px;
  background: rgba(255,255,255,0.05);
  /*border: 1px solid rgba(255,255,255,0.08);*/
  border: 1px solid var(--clr-border, rgba(255,255,255,0.12));
}

.hemkalkyl__result-label {
  margin: 0 0 0.35rem;
  font-size: 0.95rem;
  opacity: 0.85;
}

.hemkalkyl__result-value {
  margin: 0;
  font-size: clamp(1.55rem, 2.5vw, 2rem);
  font-weight: 700;
  line-height: 1.2;
}

.hemkalkyl__note {
  font-size: 0.98rem;
}

.hemkalkyl__actions {
  margin-top: var(--sp-5);
}

.hemkalkyl__microtrust {
  margin: 0.5rem 0;
  font-size: 0.85rem;
  color: #666;
}

.hemkalkyl__cta-note {
  margin: 0.4rem 0 0;
  font-size: 0.85rem;
  color: #666;
}

@media (max-width: 640px) {
  .hemkalkyl__inner {
    padding: 1rem;
  }
}